PHPWord
OpenXML - Read, Write and Create Word documents in PHP.
PHPWord is a library written in PHP that create word documents.
No Windows operating system is needed for usage because the result are docx files (Office Open XML) that can be opened by all major office software.
Want to contribute? Fork us!
Requirements
- PHP version 5.3.0 or higher
Installation
It is recommended that you install the PHPWord library through composer. To do so, add
the following lines to your composer.json.
{
"require": {
"phpoffice/phpword": "dev-master"
}
}Documentation
Table of contents
Basic usage
The following is a basic example of the PHPWord library.
$PHPWord = new PHPWord();
// Every element you want to append to the word document is placed in a section.
// To create a basic section:
$section = $PHPWord->createSection();
// After creating a section, you can append elements:
$section->addText('Hello world!');
// You can directly style your text by giving the addText function an array:
$section->addText('Hello world! I am formatted.',
array('name'=>'Tahoma', 'size'=>16, 'bold'=>true));
// If you often need the same style again you can create a user defined style
// to the word document and give the addText function the name of the style:
$PHPWord->addFontStyle('myOwnStyle',
array('name'=>'Verdana', 'size'=>14, 'color'=>'1B2232'));
$section->addText('Hello world! I am formatted by a user defined style',
'myOwnStyle');
// You can also put the appended element to local object like this:
$fontStyle = new PHPWord_Style_Font();
$fontStyle->setBold(true);
$fontStyle->setName('Verdana');
$fontStyle->setSize(22);
$myTextElement = $section->addText('Hello World!');
$myTextElement->setFontStyle($fontStyle);
// Finally, write the document:
$objWriter = PHPWord_IOFactory::createWriter($PHPWord, 'Word2007');
$objWriter->save('helloWorld.docx');Measurement units
The base length unit in Open Office XML is twip. Twip means "TWentieth of an Inch Point", i.e. 1 twip = 1/1440 inch.
You can use PHPWord helper functions to convert inches, centimeters, or points to twips.
// Paragraph with 6 points space after
$PHPWord->addParagraphStyle('My Style', array(
'spaceAfter' => PHPWord_Shared_Font::pointSizeToTwips(6))
);
$section = $PHPWord->createSection();
$sectionStyle = $section->getSettings();
// half inch left margin
$sectionStyle->setMarginLeft(PHPWord_Shared_Font::inchSizeToTwips(.5));
// 2 cm right margin
$sectionStyle->setMarginRight(PHPWord_Shared_Font::centimeterSizeToTwips(2));Sections
Every visible element in word is placed inside of a section. To create a section, use the following code:
$section = $PHPWord->createSection($sectionSettings);The $sectionSettings is an optional associative array that sets the section. Example:
$sectionSettings = array(
'orientation' => 'landscape',
'marginTop' => 600,
'colsNum' => 2,
);Section settings
Below are the available settings for section:
-
orientationPage orientation, i.e. 'portrait' (default) or 'landscape' -
marginTopPage margin top in twips -
marginLeftPage margin left in twips -
marginRightPage margin right in twips -
marginBottomPage margin bottom in twips -
borderTopSizeBorder top size in twips -
borderTopColorBorder top color -
borderLeftSizeBorder left size in twips -
borderLeftColorBorder left color -
borderRightSizeBorder right size in twips -
borderRightColorBorder right color -
borderBottomSizeBorder bottom size in twips -
borderBottomColorBorder bottom color -
headerHeightSpacing to top of header -
footerHeightSpacing to bottom of footer -
colsNumNumber of columns -
colsSpaceSpacing between columns -
breakTypeSection break type (nextPage, nextColumn, continuous, evenPage, oddPage)
The following two settings are automatically set by the use of the orientation setting. You can alter them but that's not recommended.
-
pageSizeWPage width in twips -
pageSizeHPage height in twips
Section page numbering
You can change a section page numbering.
$section = $PHPWord->createSection();
$section->getSettings()->setPageNumberingStart(1);Texts
Text can be added by using addText and createTextRun method. addText is used for creating simple paragraphs that only contain texts with the same style. createTextRun is used for creating complex paragraphs that contain text with different style (some bold, other italics, etc) or other elements, e.g. images or links.
addText sample:
$fontStyle = array('name' => 'Times New Roman', 'size' => 9);
$paragraphStyle = array('align' => 'both');
$section->addText('I am simple paragraph', $fontStyle, $paragraphStyle);createTextRun sample:
$textrun = $section->createTextRun();
$textrun->addText('I am bold', array('bold' => true));
$textrun->addText('I am italic, array('italic' => true));
$textrun->addText('I am colored, array('color' => 'AACC00'));Attributes
-
sizetext size, e.g. 20, 22, -
namefont name, e.g. Arial -
boldtext is bold, true or false -
italictext is italic, true or false -
superScripttext is super script, true or false -
subScripttext is sub script, true or false -
underlinetext is underline, true or false -
strikethroughtext is strikethrough, true or false -
colortext color, e.g. FF0000 -
fgColorfgColor -
line-heighttext line height, e.g. 1.0, 1.5, ect...
Paragraph Style
Attributes
-
line-heighttext line height, e.g. 1.0, 1.5, ect... -
alignparagraph alignment, left, right or center -
spaceBeforespace before Paragraph -
spaceAfterspace after Paragraph -
tabsset of Custom Tab Stops -
indentindent by how much
Tables
The following illustrates how to create a table.
$table = $section->addTable();
$table->addRow();
$table->addCell();Cell Style
Cell Span
You can span a cell on multiple columms.
$cell = $table->addCell(200);
$cell->getStyle()->setGridSpan(5);Images
You can add images easily using the following example.
$section = $PHPWord->createSection();
$section->addImage('mars.jpg');Attributes
-
widthwidth in pixels -
heightheight in pixels -
alignimage alignment, left, right or center -
marginToptop margin in inches, can be negative -
marginLeftleft margin in inches, can be negative -
wrappingStylecan be inline, square, tight, behind, infront
To add an image with attributes, consider the following example.
$section->addImage(
'mars.jpg',
array(
'width' => 100,
'height' => 100,
'marginTop' => -1,
'marginLeft' => -1,
'wrappingStyle' => 'behind'
)
);



