Simplify README.md and move the full documentation to RST.

This commit is contained in:
Ivan Lanin 2014-03-20 22:53:48 +07:00
parent 38a4eb785f
commit 0bd29cba82
9 changed files with 148 additions and 743 deletions

665
README.md
View File

@ -3,40 +3,10 @@
[![Build Status](https://travis-ci.org/PHPOffice/PHPWord.png?branch=master)](https://travis-ci.org/PHPOffice/PHPWord) [![Build Status](https://travis-ci.org/PHPOffice/PHPWord.png?branch=master)](https://travis-ci.org/PHPOffice/PHPWord)
[![Latest Stable Version](https://poser.pugx.org/phpoffice/phpword/v/stable.png)](https://packagist.org/packages/phpoffice/phpword) [![Total Downloads](https://poser.pugx.org/phpoffice/phpword/downloads.png)](https://packagist.org/packages/phpoffice/phpword) [![Latest Unstable Version](https://poser.pugx.org/phpoffice/phpword/v/unstable.png)](https://packagist.org/packages/phpoffice/phpword) [![License](https://poser.pugx.org/phpoffice/phpword/license.png)](https://packagist.org/packages/phpoffice/phpword) [![Latest Stable Version](https://poser.pugx.org/phpoffice/phpword/v/stable.png)](https://packagist.org/packages/phpoffice/phpword) [![Total Downloads](https://poser.pugx.org/phpoffice/phpword/downloads.png)](https://packagist.org/packages/phpoffice/phpword) [![Latest Unstable Version](https://poser.pugx.org/phpoffice/phpword/v/unstable.png)](https://packagist.org/packages/phpoffice/phpword) [![License](https://poser.pugx.org/phpoffice/phpword/license.png)](https://packagist.org/packages/phpoffice/phpword)
<a name="contents"></a>
# Contents
- [Introduction](#introduction)
- [Installing](#installing)
- [General usage](#general-usage)
- [Containers](#containers)
- [Sections](#sections)
- [Headers](#headers)
- [Footers](#footers)
- [Elements](#elements)
- [Texts](#texts)
- [Breaks](#breaks)
- [Lists](#lists)
- [Tables](#tables)
- [Images](#images)
- [Objects](#images)
- [Table of contents](#toc)
- [Footnotes](#footnotes)
- [Templates](#templates)
- [References](#references)
<a name="introduction"></a>
# Introduction
PHPWord is a library written in pure PHP that provides a set of classes to write to and read from different document file formats. The current version of PHPWord supports Microsoft [Office Open XML](http://en.wikipedia.org/wiki/Office_Open_XML) (OOXML or OpenXML), OASIS [Open Document Format for Office Applications](http://en.wikipedia.org/wiki/OpenDocument) (OpenDocument or ODF), and [Rich Text Format](http://en.wikipedia.org/wiki/Rich_Text_Format) (RTF). PHPWord is a library written in pure PHP that provides a set of classes to write to and read from different document file formats. The current version of PHPWord supports Microsoft [Office Open XML](http://en.wikipedia.org/wiki/Office_Open_XML) (OOXML or OpenXML), OASIS [Open Document Format for Office Applications](http://en.wikipedia.org/wiki/OpenDocument) (OpenDocument or ODF), and [Rich Text Format](http://en.wikipedia.org/wiki/Rich_Text_Format) (RTF).
No Windows operating system is needed for usage because the resulting DOCX, ODT, or RTF files can be opened by all major [word processing softwares](http://en.wikipedia.org/wiki/List_of_word_processors). With PHPWord, you can create DOCX, ODT, or RTF documents dynamically using your PHP 5.3+ scripts. Below are some of the things that you can do with PHPWord library:
PHPWord is an open source project licensed under [LGPL](license.md). PHPWord is [unit tested](https://travis-ci.org/PHPOffice/PHPWord) to make sure that the released versions are stable.
__Want to contribute?__ [Fork us](https://github.com/PHPOffice/PHPWord/fork) or [submit](https://github.com/PHPOffice/PHPWord/issues) your bug reports or feature requests to us.
## Features
* Set document properties, e.g. title, subject, and creator. * Set document properties, e.g. title, subject, and creator.
* Create document sections with different settings, e.g. portrait/landscape, page size, and page numbering * Create document sections with different settings, e.g. portrait/landscape, page size, and page numbering
@ -56,636 +26,7 @@ __Want to contribute?__ [Fork us](https://github.com/PHPOffice/PHPWord/fork) or
* Use XSL 1.0 style sheets to transform main document part of OOXML template * Use XSL 1.0 style sheets to transform main document part of OOXML template
* ... and many more features on progress * ... and many more features on progress
## File formats __Want to contribute?__ [Fork us](https://github.com/PHPOffice/PHPWord/fork) or [submit](https://github.com/PHPOffice/PHPWord/issues) your bug reports or feature requests to us.
Below are the supported features for each file formats. __Want to know more?__ Read the full documentation of PHPWord on [Read The Docs](http://phpword.readthedocs.org/en/develop/).
### Writers
| No | Element | DOCX | ODT | RTF |
|----|---------------|:----:|:---:|:---:|
| 1 | Text | v | v | v |
| 2 | Text Run | v | v | v |
| 3 | Title | v | | |
| 4 | Link | v | | |
| 5 | Preserve Text | v | | |
| 6 | Text Break | v | v | v |
| 7 | Page Break | v | | |
| 8 | List | v | | |
| 9 | Table | v | | |
| 10 | Image | v | | |
| 11 | MemoryImage | v | | |
| 12 | Object | v | | |
| 13 | Watermark | v | | |
| 14 | TOC | v | | |
| 15 | Header | v | | |
| 16 | Footer | v | | |
| 17 | Footnote | v | | |
### Readers
| No | Element | DOCX | ODT | RTF |
|----|---------------|:----:|:---:|:---:|
| 1 | Text | v | | |
| 2 | Text Run | v | | |
| 3 | Title | | | |
| 4 | Link | | | |
| 5 | Preserve Text | | | |
| 6 | Text Break | v | | |
| 7 | Page Break | | | |
| 8 | List | | | |
| 9 | Table | | | |
| 10 | Image | | | |
| 11 | MemoryImage | | | |
| 12 | Object | | | |
| 13 | Watermark | | | |
| 14 | TOC | | | |
| 15 | Header | | | |
| 16 | Footer | | | |
| 17 | Footnote | | | |
<a name="installing"></a>
# Installing/Configuring
## Requirements
Mandatory:
* PHP 5.3+
* PHP [Zip](http://php.net/manual/en/book.zip.php) extension
* PHP [XML Parser](http://www.php.net/manual/en/xml.installation.php) extension
Optional PHP extensions:
* [GD](http://php.net/manual/en/book.image.php)
* [XMLWriter](http://php.net/manual/en/book.xmlwriter.php)
* [XSL](http://php.net/manual/en/book.xsl.php)
## Installation
There are two ways to install PHPWord, i.e. via [Composer](http://getcomposer.org/) or manually by downloading the library.
### Using Composer
To install via Composer, add the following lines to your ``composer.json``:
```json
{
"require": {
"phpoffice/phpword": "dev-master"
}
}
```
### Manual install
To install manually, [download PHPWord package from github](https://github.com/PHPOffice/PHPWord/archive/master.zip). Extract the package and put the contents to your machine. To use the library, include `Classes/PHPWord.php` in your script like below.
```php
require_once '/path/to/PHPWord/Classes/PHPWord.php';
```
## Using samples
After installation, you can browse and use the samples that we've provided, either by command line or using browser. If you can access your PHPWord library folder using browser, point your browser to the `samples` folder, e.g. `http://localhost/PHPWord/samples/`.
<a name="general-usage"></a>
# General usage
## Basic example
The following is a basic example of the PHPWord library. More examples are provided in the [samples folder](samples/).
```php
$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');
```
## Default font
By default, every text appears in Arial 10 point. You can alter the default font by using the following two functions:
```php
$phpWord->setDefaultFontName('Times New Roman');
$phpWord->setDefaultFontSize(12);
```
## Document properties
You can set the document properties such as title, creator, and company name. Use the following functions:
```php
$properties = $PHPWord->getProperties();
$properties->setCreator('My name');
$properties->setCompany('My factory');
$properties->setTitle('My title');
$properties->setDescription('My description');
$properties->setCategory('My category');
$properties->setLastModifiedBy('My name');
$properties->setCreated(mktime(0, 0, 0, 3, 12, 2014));
$properties->setModified(mktime(0, 0, 0, 3, 14, 2014));
$properties->setSubject('My subject');
$properties->setKeywords('my, key, word');
```
<a name="measurement-units"></a>
## 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.
```php
// 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));
```
<a name="containers"></a>
# Containers
Containers are objects where you can put elements (texts, lists, tables, etc). There are 3 main containers, i.e. sections, headers, and footers. There are 3 elements that can also act as containers, i.e. textruns, table cells, and footnotes.
<a name="sections"></a>
## Sections
Every visible element in word is placed inside of a section. To create a section, use the following code:
```php
$section = $phpWord->createSection($sectionSettings);
```
The `$sectionSettings` is an optional associative array that sets the section. Example:
```php
$sectionSettings = array(
'orientation' => 'landscape',
'marginTop' => 600,
'colsNum' => 2,
);
```
<a name="section-settings"></a>
### Section settings
Below are the available settings for section:
* `orientation` Page orientation, i.e. 'portrait' (default) or 'landscape'
* `marginTop` Page margin top in twips
* `marginLeft` Page margin left in twips
* `marginRight` Page margin right in twips
* `marginBottom` Page margin bottom in twips
* `borderTopSize` Border top size in twips
* `borderTopColor` Border top color
* `borderLeftSize` Border left size in twips
* `borderLeftColor` Border left color
* `borderRightSize` Border right size in twips
* `borderRightColor` Border right color
* `borderBottomSize` Border bottom size in twips
* `borderBottomColor` Border bottom color
* `headerHeight` Spacing to top of header
* `footerHeight` Spacing to bottom of footer
* `colsNum` Number of columns
* `colsSpace` Spacing between columns
* `breakType` Section 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.
* `pageSizeW` Page width in twips
* `pageSizeH` Page height in twips
<a name="page-numbering"></a>
### Page number
You can change a section page number by using the `pageNumberingStart` property of the section.
```php
// Method 1
$section = $phpWord->createSection(array('pageNumberingStart' => 1));
// Method 2
$section = $phpWord->createSection();
$section->getSettings()->setPageNumberingStart(1);
```
<a name="multicolumn"></a>
### Multicolumn
You can change a section layout to multicolumn (like in a newspaper) by using the `breakType` and `colsNum` property of the section.
```php
// Method 1
$section = $phpWord->createSection(array('breakType' => 'continuous', 'colsNum' => 2));
// Method 2
$section = $phpWord->createSection();
$section->getSettings()->setBreakType('continuous');
$section->getSettings()->setColsNum(2);
```
<a name="headers"></a>
## Headers
Each section can have its own header reference. To create a header use the `createHeader` method:
```php
$header = $section->createHeader();
```
Be sure to save the result in a local object. You can use all elements that are available for the footer. See "Footer" section for detail. Additionally, only inside of the header reference you can add watermarks or background pictures. See "Watermarks" section.
<a name="footers"></a>
## Footers
Each section can have its own footer reference. To create a footer, use the `createFooter` method:
```php
$footer = $section->createFooter();
```
Be sure to save the result in a local object to add elements to a footer. You can add the following elements to footers:
* Texts `addText` and `createTextrun`
* Text breaks
* Images
* Tables
* Preserve text
See the "Elements" section for the detail of each elements.
<a name="other-containers"></a>
## Other containers
Textruns, table cells, and footnotes are elements that can also act as containers. See the corresponding "Elements" section for the detail of each elements.
<a name="elements"></a>
# Elements
<a name="texts"></a>
## 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. The syntaxes are as follow:
```php
$section->addText($text, [$fontStyle], [$paragraphStyle]);
$textrun = $section->createTextRun([$paragraphStyle]);
```
### Text styles
You can use the `$fontStyle` and `$paragraphStyle` variable to define text formatting. There are 2 options to style the inserted text elements, i.e. inline style by using array or defined style by adding style definition.
Inline style examples:
```php
$fontStyle = array('name' => 'Times New Roman', 'size' => 9);
$paragraphStyle = array('align' => 'both');
$section->addText('I am simple paragraph', $fontStyle, $paragraphStyle);
$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'));
```
Defined style examples:
```php
$fontStyle = array('color' => '006699', 'size' => 18, 'bold' => true);
$PHPWord->addFontStyle('fStyle', $fontStyle);
$text = $section->addText('Hello world!', 'fStyle');
$paragraphStyle = array('align' => 'center');
$PHPWord->addParagraphStyle('pStyle', $paragraphStyle);
$text = $section->addText('Hello world!', 'pStyle');
```
<a name="font-style"></a>
#### Font style
Available font styles:
* ``name`` Font name, e.g. _Arial_
* ``size`` Font size, e.g. _20_, _22_,
* ``hint`` Font content type, _default_, _eastAsia_, or _cs_
* ``bold`` Bold, _true_ or _false_
* ``italic`` Italic, _true_ or _false_
* ``superScript`` Superscript, _true_ or _false_
* ``subScript`` Subscript, _true_ or _false_
* ``underline`` Underline, _dash_, _dotted_, etc.
* ``strikethrough`` Strikethrough, _true_ or _false_
* ``color`` Font color, e.g. _FF0000_
* ``fgColor`` Font highlight color, e.g. _yellow_, _green_, _blue_
<a name="paragraph-style"></a>
#### Paragraph style
Available paragraph styles:
* ``align`` Paragraph alignment, _left_, _right_ or _center_
* ``spaceBefore`` Space before paragraph
* ``spaceAfter`` Space after paragraph
* ``indent`` Indent by how much
* ``hanging`` Hanging by how much
* ``basedOn`` Parent style
* ``next`` Style for next paragraph
* ``widowControl`` Allow first/last line to display on a separate page, _true_ or _false_
* ``keepNext`` Keep paragraph with next paragraph, _true_ or _false_
* ``keepLines`` Keep all lines on one page, _true_ or _false_
* ``pageBreakBefore`` Start paragraph on next page, _true_ or _false_
* ``lineHeight`` text line height, e.g. _1.0_, _1.5_, ect...
* ``tabs`` Set of custom tab stops
<a name="titles"></a>
### Titles
If you want to structure your document or build table of contents, you need titles or headings. To add a title to the document, use the `addTitleStyle` and `addTitle` method.
```php
$PHPWord->addTitleStyle($depth, [$fontStyle], [$paragraphStyle]);
$section->addTitle($text, [$depth]);
```
Its necessary to add a title style to your document because otherwise the title won't be detected as a real title.
<a name="links"></a>
### Links
You can add Hyperlinks to the document by using the function addLink:
```php
$section->addLink($linkSrc, [$linkName], [$fontStyle], [$paragraphStyle]);
```
* ``$linkSrc`` The URL of the link.
* ``$linkName`` Placeholder of the URL that appears in the document.
* ``$fontStyle`` See "Font style" section.
* ``$paragraphStyle`` See "Paragraph style" section.
### Preserve texts
The `addPreserveText` method is used to add a page number or page count to headers or footers.
```php
$footer->addPreserveText('Page {PAGE} of {NUMPAGES}.');
```
<a name="breaks"></a>
## Breaks
### Text breaks
Text breaks are empty new lines. To add text breaks, use the following syntax. All paramaters are optional.
```php
$section->addTextBreak([$breakCount], [$fontStyle], [$paragraphStyle]);
```
* ``$breakCount`` How many lines
* ``$fontStyle`` See "Font style" section.
* ``$paragraphStyle`` See "Paragraph style" section.
### Page breaks
There are two ways to insert a page breaks, using the `addPageBreak` method or using the `pageBreakBefore` style of paragraph.
```
$section->addPageBreak();
```
<a name="lists"></a>
## Lists
To add a list item use the function `addListItem`.
```php
$section->addListItem($text, [$depth], [$fontStyle], [$listStyle], [$paragraphStyle]);
```
* ``$text`` Text that appears in the document.
* ``$depth`` Depth of list item.
* ``$fontStyle`` See "Font style" section.
* ``$listStyle`` List style of the current element TYPE_NUMBER, TYPE_ALPHANUM, TYPE_BULLET_FILLED, etc. See list of constants in PHPWord_Style_ListItem.
* ``$paragraphStyle`` See "Paragraph style" section.
<a name="tables"></a>
## Tables
To add tables, rows, and cells, use the `addTable`, `addRow`, and `addCell` methods:
```php
$table = $section->addTable([$tableStyle]);
$table->addRow([$height], [$rowStyle]);
$cell = $table->addCell($width, [$cellStyle]);
```
Table style can be defined with `addTableStyle`:
```php
$tableStyle = array(
'borderColor' => '006699',
'borderSize' => 6,
'cellMargin' => 50
);
$firstRowStyle = array('bgColor' => '66BBFF');
$PHPWord->addTableStyle('myTable', $tableStyle, $firstRowStyle);
$table = $section->addTable('myTable');
```
### Table, row, and cell styles
Table styles:
* ``$width`` Table width in percent
* ``$bgColor`` Background color, e.g. '9966CC'
* ``$border(Top|Right|Bottom|Left)Size`` Border size in twips
* ``$border(Top|Right|Bottom|Left)Color`` Border color, e.g. '9966CC'
* ``$cellMargin(Top|Right|Bottom|Left) `` Cell margin in twips
Row styles:
* ``tblHeader`` Repeat table row on every new page, _true_ or _false_
* ``cantSplit`` Table row cannot break across pages, _true_ or _false_
Cell styles:
* ``$width`` Cell width in twips
* ``$valign`` Vertical alignment, _top_, _center_, _both_, _bottom_
* ``$textDirection`` Direction of text
* ``$bgColor`` Background color, e.g. '9966CC'
* ``$border(Top|Right|Bottom|Left)Size`` Border size in twips
* ``$border(Top|Right|Bottom|Left)Color`` Border color, e.g. '9966CC'
* ``$gridSpan `` Number of columns spanned
* ``$vMerge `` _restart_ or _continue_
### Cell span
You can span a cell on multiple columns by using `gridSpan` or multiple rows by using `vMerge`.
```php
$cell = $table->addCell(200);
$cell->getStyle()->setGridSpan(5);
```
See `Sample_09_Tables.php` for more code sample.
<a name="images"></a>
## Images
To add an image, use the `addImage` or `addMemoryImage` method. The first one is used when your source is stored locally, the later is used when your source is a remote URL, either another script that create image or an image on the internet.
Syntax:
```php
$section->addImage($src, [$style]);
$section->addMemoryImage($link, [$style]);
```
Examples:
```php
$section = $phpWord->createSection();
$section->addImage(
'mars.jpg',
array(
'width' => 100,
'height' => 100,
'marginTop' => -1,
'marginLeft' => -1,
'wrappingStyle' => 'behind'
)
);
$section->addMemoryImage('http://example.com/image.php');
$section->addMemoryImage('http://php.net/logo.jpg');
```
### Image styles
Available image styles:
* ``width`` Width in pixels
* ``height`` Height in pixels
* ``align`` Image alignment, _left_, _right_, or _center_
* ``marginTop`` Top margin in inches, can be negative
* ``marginLeft`` Left margin in inches, can be negative
* ``wrappingStyle`` Wrapping style, _inline_, _square_, _tight_, _behind_, or _infront_
### Watermarks
To add a watermark (or page background image), your section needs a header reference. After creating a header, you can use the `addWatermark` method to add a watermark.
```php
$section = $PHPWord->createSection();
$header = $section->createHeader();
$header->addWatermark('resources/_earth.jpg', array('marginTop' => 200, 'marginLeft' => 55));
```
<a name="objects"></a>
## Objects
You can add OLE embeddings, such as Excel spreadsheets or PowerPoint presentations to the document by using `addObject` method.
```php
$section->addObject($src, [$style]);
```
<a name="toc"></a>
## Table of contents
To add a table of contents (TOC), you can use the `addTOC` method. Your TOC can only be generated if you have add at least one title (See "Titles").
```php
$section->addTOC([$fontStyle], [$tocStyle]);
```
* ``tabLeader`` Fill type between the title text and the page number. Use the defined constants in PHPWord_Style_TOC.
* ``tabPos`` The position of the tab where the page number appears in twips.
* ``indent`` The indent factor of the titles in twips.
<a name="footnotes"></a>
## Footnotes
You can create footnotes in texts or textruns, but it's recommended to use textrun to have better layout.
On textrun:
```php
$textrun = $section->createTextRun();
$textrun->addText('Lead text.');
$footnote = $textrun->createFootnote();
$footnote->addText('Footnote text.');
$textrun->addText('Trailing text.');
```
On text:
```php
$section->addText('Lead text.');
$footnote = $section->createFootnote();
$footnote->addText('Footnote text.');
```
<a name="templates"></a>
# Templates
You can create a docx template with included search-patterns that can be replaced by any value you wish. Only single-line values can be replaced. To load a template file, use the `loadTemplate` method. After loading the docx template, you can use the `setValue` method to change the value of a search pattern. The search-pattern model is: `${search-pattern}`. It is not possible to add new PHPWord elements to a loaded template file.
Example:
```php
$template = $PHPWord->loadTemplate('Template.docx');
$template->setValue('Name', 'Somebody someone');
$template->setValue('Street', 'Coming-Undone-Street 32');
```
See `Sample_07_TemplateCloneRow.php` for more code sample, including how to create multirow from a single row in a template by using `cloneRow`.
<a name="references"></a>
# References
## Formal specifications
* [Office Open XML (OOXML) (ECMA-376) Schema](http://www.schemacentral.com/sc/ooxml/ss.html)
* [Oasis OpenDocument Standard Version 1.2](http://docs.oasis-open.org/office/v1.2/os/OpenDocument-v1.2-os.html)
* [Rich Text Format (RTF) Specification, version 1.9.1](http://www.microsoft.com/en-us/download/details.aspx?id=10725)
## Other resources
* [DocumentFormat.OpenXml.Wordprocessing Namespace on MSDN](http://msdn.microsoft.com/en-us/library/documentformat.openxml.wordprocessing%28v=office.14%29.aspx)

View File

@ -3,6 +3,11 @@
Containers Containers
========== ==========
Containers are objects where you can put elements (texts, lists, tables,
etc). There are 3 main containers, i.e. sections, headers, and footers.
There are 3 elements that can also act as containers, i.e. textruns,
table cells, and footnotes.
Sections Sections
-------- --------
@ -29,8 +34,8 @@ Section settings
Below are the available settings for section: Below are the available settings for section:
- ``orientation`` Page orientation, i.e. portrait (default) or - ``orientation`` Page orientation, i.e. 'portrait' (default) or
landscape 'landscape'
- ``marginTop`` Page margin top in twips - ``marginTop`` Page margin top in twips
- ``marginLeft`` Page margin left in twips - ``marginLeft`` Page margin left in twips
- ``marginRight`` Page margin right in twips - ``marginRight`` Page margin right in twips
@ -51,21 +56,42 @@ Below are the available settings for section:
evenPage, oddPage) evenPage, oddPage)
The following two settings are automatically set by the use of the The following two settings are automatically set by the use of the
``orientation`` setting. You can alter them but thats not recommended. ``orientation`` setting. You can alter them but that's not recommended.
- ``pageSizeW`` Page width in twips - ``pageSizeW`` Page width in twips
- ``pageSizeH`` Page height in twips - ``pageSizeH`` Page height in twips
Section page numbering Page number
~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~
You can change a section page numbering. You can change a section page number by using the ``pageNumberingStart``
property of the section.
.. code:: php .. code:: php
// Method 1
$section = $phpWord->createSection(array('pageNumberingStart' => 1));
// Method 2
$section = $phpWord->createSection(); $section = $phpWord->createSection();
$section->getSettings()->setPageNumberingStart(1); $section->getSettings()->setPageNumberingStart(1);
Multicolumn
~~~~~~~~~~~
You can change a section layout to multicolumn (like in a newspaper) by
using the ``breakType`` and ``colsNum`` property of the section.
.. code:: php
// Method 1
$section = $phpWord->createSection(array('breakType' => 'continuous', 'colsNum' => 2));
// Method 2
$section = $phpWord->createSection();
$section->getSettings()->setBreakType('continuous');
$section->getSettings()->setColsNum(2);
Headers Headers
------- -------
@ -77,9 +103,9 @@ the ``createHeader`` method:
$header = $section->createHeader(); $header = $section->createHeader();
Be sure to save the result in a local object. You can use all elements Be sure to save the result in a local object. You can use all elements
that are available for the footer. See “Footer” section for detail. that are available for the footer. See "Footer" section for detail.
Additionally, only inside of the header reference you can add watermarks Additionally, only inside of the header reference you can add watermarks
or background pictures. See “Watermarks” section. or background pictures. See "Watermarks" section.
Footers Footers
------- -------
@ -100,4 +126,11 @@ footer. You can add the following elements to footers:
- Tables - Tables
- Preserve text - Preserve text
See the “Elements” section for the detail of each elements. See the "Elements" section for the detail of each elements.
Other containers
----------------
Textruns, table cells, and footnotes are elements that can also act as
containers. See the corresponding "Elements" section for the detail of
each elements.

View File

@ -18,6 +18,9 @@ syntaxes are as follow:
$section->addText($text, [$fontStyle], [$paragraphStyle]); $section->addText($text, [$fontStyle], [$paragraphStyle]);
$textrun = $section->createTextRun([$paragraphStyle]); $textrun = $section->createTextRun([$paragraphStyle]);
Text styles
~~~~~~~~~~~
You can use the ``$fontStyle`` and ``$paragraphStyle`` variable to You can use the ``$fontStyle`` and ``$paragraphStyle`` variable to
define text formatting. There are 2 options to style the inserted text define text formatting. There are 2 options to style the inserted text
elements, i.e. inline style by using array or defined style by adding elements, i.e. inline style by using array or defined style by adding
@ -49,7 +52,7 @@ Defined style examples:
$text = $section->addText('Hello world!', 'pStyle'); $text = $section->addText('Hello world!', 'pStyle');
Font style Font style
~~~~~~~~~~ ^^^^^^^^^^
Available font styles: Available font styles:
@ -66,7 +69,7 @@ Available font styles:
- ``fgColor`` Font highlight color, e.g. *yellow*, *green*, *blue* - ``fgColor`` Font highlight color, e.g. *yellow*, *green*, *blue*
Paragraph style Paragraph style
~~~~~~~~~~~~~~~ ^^^^^^^^^^^^^^^
Available paragraph styles: Available paragraph styles:
@ -82,7 +85,7 @@ Available paragraph styles:
- ``keepNext`` Keep paragraph with next paragraph, *true* or *false* - ``keepNext`` Keep paragraph with next paragraph, *true* or *false*
- ``keepLines`` Keep all lines on one page, *true* or *false* - ``keepLines`` Keep all lines on one page, *true* or *false*
- ``pageBreakBefore`` Start paragraph on next page, *true* or *false* - ``pageBreakBefore`` Start paragraph on next page, *true* or *false*
- ``lineHeight`` text line height, e.g. *1.0*, *1.5*, ect - ``lineHeight`` text line height, e.g. *1.0*, *1.5*, ect...
- ``tabs`` Set of custom tab stops - ``tabs`` Set of custom tab stops
Titles Titles
@ -98,7 +101,7 @@ need titles or headings. To add a title to the document, use the
$section->addTitle($text, [$depth]); $section->addTitle($text, [$depth]);
Its necessary to add a title style to your document because otherwise Its necessary to add a title style to your document because otherwise
the title wont be detected as a real title. the title won't be detected as a real title.
Links Links
~~~~~ ~~~~~
@ -111,8 +114,8 @@ You can add Hyperlinks to the document by using the function addLink:
- ``$linkSrc`` The URL of the link. - ``$linkSrc`` The URL of the link.
- ``$linkName`` Placeholder of the URL that appears in the document. - ``$linkName`` Placeholder of the URL that appears in the document.
- ``$fontStyle`` See “Font style” section. - ``$fontStyle`` See "Font style" section.
- ``$paragraphStyle`` See “Paragraph style” section. - ``$paragraphStyle`` See "Paragraph style" section.
Preserve texts Preserve texts
~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~
@ -138,8 +141,8 @@ syntax. All paramaters are optional.
$section->addTextBreak([$breakCount], [$fontStyle], [$paragraphStyle]); $section->addTextBreak([$breakCount], [$fontStyle], [$paragraphStyle]);
- ``$breakCount`` How many lines - ``$breakCount`` How many lines
- ``$fontStyle`` See “Font style” section. - ``$fontStyle`` See "Font style" section.
- ``$paragraphStyle`` See “Paragraph style” section. - ``$paragraphStyle`` See "Paragraph style" section.
Page breaks Page breaks
~~~~~~~~~~~ ~~~~~~~~~~~
@ -162,11 +165,11 @@ To add a list item use the function ``addListItem``.
- ``$text`` Text that appears in the document. - ``$text`` Text that appears in the document.
- ``$depth`` Depth of list item. - ``$depth`` Depth of list item.
- ``$fontStyle`` See “Font style” section. - ``$fontStyle`` See "Font style" section.
- ``$listStyle`` List style of the current element TYPE\_NUMBER, - ``$listStyle`` List style of the current element TYPE\_NUMBER,
TYPE\_ALPHANUM, TYPE\_BULLET\_FILLED, etc. See list of constants in TYPE\_ALPHANUM, TYPE\_BULLET\_FILLED, etc. See list of constants in
PHPWord\_Style\_ListItem. PHPWord\_Style\_ListItem.
- ``$paragraphStyle`` See “Paragraph style” section. - ``$paragraphStyle`` See "Paragraph style" section.
Tables Tables
------ ------
@ -193,12 +196,15 @@ Table style can be defined with ``addTableStyle``:
$PHPWord->addTableStyle('myTable', $tableStyle, $firstRowStyle); $PHPWord->addTableStyle('myTable', $tableStyle, $firstRowStyle);
$table = $section->addTable('myTable'); $table = $section->addTable('myTable');
Table, row, and cell styles
~~~~~~~~~~~~~~~~~~~~~~~~~~~
Table styles: Table styles:
- ``$width`` Table width in percent - ``$width`` Table width in percent
- ``$bgColor`` Background color, e.g. 9966CC - ``$bgColor`` Background color, e.g. '9966CC'
- ``$border(Top|Right|Bottom|Left)Size`` Border size in twips - ``$border(Top|Right|Bottom|Left)Size`` Border size in twips
- ``$border(Top|Right|Bottom|Left)Color`` Border color, e.g. 9966CC - ``$border(Top|Right|Bottom|Left)Color`` Border color, e.g. '9966CC'
- ``$cellMargin(Top|Right|Bottom|Left)`` Cell margin in twips - ``$cellMargin(Top|Right|Bottom|Left)`` Cell margin in twips
Row styles: Row styles:
@ -211,22 +217,25 @@ Cell styles:
- ``$width`` Cell width in twips - ``$width`` Cell width in twips
- ``$valign`` Vertical alignment, *top*, *center*, *both*, *bottom* - ``$valign`` Vertical alignment, *top*, *center*, *both*, *bottom*
- ``$textDirection`` Direction of text - ``$textDirection`` Direction of text
- ``$bgColor`` Background color, e.g. 9966CC - ``$bgColor`` Background color, e.g. '9966CC'
- ``$border(Top|Right|Bottom|Left)Size`` Border size in twips - ``$border(Top|Right|Bottom|Left)Size`` Border size in twips
- ``$border(Top|Right|Bottom|Left)Color`` Border color, e.g. 9966CC - ``$border(Top|Right|Bottom|Left)Color`` Border color, e.g. '9966CC'
- ``$gridSpan`` Number of columns spanned - ``$gridSpan`` Number of columns spanned
- ``$vMerge`` *restart* or *continue* - ``$vMerge`` *restart* or *continue*
Cell span Cell span
~~~~~~~~~ ~~~~~~~~~
You can span a cell on multiple columms. You can span a cell on multiple columns by using ``gridSpan`` or
multiple rows by using ``vMerge``.
.. code:: php .. code:: php
$cell = $table->addCell(200); $cell = $table->addCell(200);
$cell->getStyle()->setGridSpan(5); $cell->getStyle()->setGridSpan(5);
See ``Sample_09_Tables.php`` for more code sample.
Images Images
------ ------
@ -302,7 +311,7 @@ Table of contents
To add a table of contents (TOC), you can use the ``addTOC`` method. To add a table of contents (TOC), you can use the ``addTOC`` method.
Your TOC can only be generated if you have add at least one title (See Your TOC can only be generated if you have add at least one title (See
“Titles”). "Titles").
.. code:: php .. code:: php
@ -317,7 +326,7 @@ Your TOC can only be generated if you have add at least one title (See
Footnotes Footnotes
--------- ---------
You can create footnotes in texts or textruns, but its recommended to You can create footnotes in texts or textruns, but it's recommended to
use textrun to have better layout. use textrun to have better layout.
On textrun: On textrun:

View File

@ -7,7 +7,7 @@ Basic example
------------- -------------
The following is a basic example of the PHPWord library. More examples The following is a basic example of the PHPWord library. More examples
are provided in the `samples folder`. are provided in the `samples folder <samples/>`__.
.. code:: php .. code:: php
@ -77,8 +77,8 @@ name. Use the following functions:
Measurement units Measurement units
----------------- -----------------
The base length unit in Open Office XML is twip. Twip means TWentieth The base length unit in Open Office XML is twip. Twip means "TWentieth
of an Inch Point, i.e. 1 twip = 1/1440 inch. of an Inch Point", i.e. 1 twip = 1/1440 inch.
You can use PHPWord helper functions to convert inches, centimeters, or You can use PHPWord helper functions to convert inches, centimeters, or
points to twips. points to twips.

View File

@ -3,10 +3,16 @@
You can adapt this file completely to your liking, but it should at least You can adapt this file completely to your liking, but it should at least
contain the root `toctree` directive. contain the root `toctree` directive.
Welcome to PHPWord's documentation! Welcome to PHPWord's documentation
=================================== ==================================
Contents: |PHPWord|
PHPWord is a library written in pure PHP that provides a set of classes to
write to and read from different document file formats. The current version of
PHPWord supports Microsoft Office Open XML (OOXML or OpenXML), OASIS Open
Document Format for Office Applications (OpenDocument or ODF), and Rich Text
Format (RTF).
.. toctree:: .. toctree::
:maxdepth: 2 :maxdepth: 2
@ -17,11 +23,11 @@ Contents:
containers containers
elements elements
templates templates
references
recipes recipes
faq faq
credits credits
Indices and tables Indices and tables
================== ==================
@ -29,3 +35,4 @@ Indices and tables
* :ref:`modindex` * :ref:`modindex`
* :ref:`search` * :ref:`search`
.. |PHPWord| image:: https://raw.github.com/PHPOffice/PHPWord/develop/docs/images/phpword.png

View File

@ -5,35 +5,32 @@ Introduction
PHPWord is a library written in pure PHP that provides a set of classes PHPWord is a library written in pure PHP that provides a set of classes
to write to and read from different document file formats. The current to write to and read from different document file formats. The current
version of PHPWord supports Microsoft `Office Open XML`_ (OOXML or version of PHPWord supports Microsoft `Office Open
OpenXML), OASIS `Open Document Format for Office Applications`_ XML <http://en.wikipedia.org/wiki/Office_Open_XML>`__ (OOXML or
(OpenDocument or ODF), and `Rich Text Format`_ (RTF). OpenXML), OASIS `Open Document Format for Office
Applications <http://en.wikipedia.org/wiki/OpenDocument>`__
(OpenDocument or ODF), and `Rich Text
Format <http://en.wikipedia.org/wiki/Rich_Text_Format>`__ (RTF).
No Windows operating system is needed for usage because the resulting No Windows operating system is needed for usage because the resulting
DOCX, ODT, or RTF files can be opened by all major `word processing DOCX, ODT, or RTF files can be opened by all major `word processing
softwares`_. softwares <http://en.wikipedia.org/wiki/List_of_word_processors>`__.
PHPWord is an open source project licensed under `LGPL`_. PHPWord is PHPWord is an open source project licensed under `LGPL <license.md>`__.
`unit tested`_ to make sure that the released versions are stable. PHPWord is `unit tested <https://travis-ci.org/PHPOffice/PHPWord>`__ to
make sure that the released versions are stable.
**Want to contribute?** `Fork us`_ or `submit`_ your bug reports or **Want to contribute?** `Fork
feature requests to us. us <https://github.com/PHPOffice/PHPWord/fork>`__ or
`submit <https://github.com/PHPOffice/PHPWord/issues>`__ your bug
.. _Office Open XML: http://en.wikipedia.org/wiki/Office_Open_XML reports or feature requests to us.
.. _Open Document Format for Office Applications: http://en.wikipedia.org/wiki/OpenDocument
.. _Rich Text Format: http://en.wikipedia.org/wiki/Rich_Text_Format
.. _word processing softwares: http://en.wikipedia.org/wiki/List_of_word_processors
.. _LGPL: license.md
.. _unit tested: https://travis-ci.org/PHPOffice/PHPWord
.. _Fork us: https://github.com/PHPOffice/PHPWord/fork
.. _submit: https://github.com/PHPOffice/PHPWord/issues
Features Features
-------- --------
- Set document properties, e.g. title, subject, and creator. - Set document properties, e.g. title, subject, and creator.
- Create document sections with different settings, - Create document sections with different settings, e.g.
e.g. portrait/landscape, page size, and page numbering portrait/landscape, page size, and page numbering
- Create header and footer for each sections - Create header and footer for each sections
- Set default font type, font size, and paragraph style - Set default font type, font size, and paragraph style
- Use UTF-8 and East Asia fonts/characters - Use UTF-8 and East Asia fonts/characters
@ -54,7 +51,7 @@ Features
- Create document from templates - Create document from templates
- Use XSL 1.0 style sheets to transform main document part of OOXML - Use XSL 1.0 style sheets to transform main document part of OOXML
template template
- and many more features on progress - ... and many more features on progress
File formats File formats
------------ ------------

20
docs/references.rst Normal file
View File

@ -0,0 +1,20 @@
.. _references:
References
==========
Formal specifications
---------------------
- `Office Open XML (OOXML) (ECMA-376)
Schema <http://www.schemacentral.com/sc/ooxml/ss.html>`__
- `Oasis OpenDocument Standard Version
1.2 <http://docs.oasis-open.org/office/v1.2/os/OpenDocument-v1.2-os.html>`__
- `Rich Text Format (RTF) Specification, version
1.9.1 <http://www.microsoft.com/en-us/download/details.aspx?id=10725>`__
Other resources
---------------
- `DocumentFormat.OpenXml.Wordprocessing Namespace on
MSDN <http://msdn.microsoft.com/en-us/library/documentformat.openxml.wordprocessing%28v=office.14%29.aspx>`__

View File

@ -1,7 +1,7 @@
.. _setup: .. _setup:
Installing Installing/Configuring
========== ======================
Requirements Requirements
------------ ------------
@ -9,29 +9,26 @@ Requirements
Mandatory: Mandatory:
- PHP 5.3+ - PHP 5.3+
- PHP `Zip`_ extension - PHP `Zip <http://php.net/manual/en/book.zip.php>`__ extension
- PHP `XML Parser`_ extension - PHP `XML
Parser <http://www.php.net/manual/en/xml.installation.php>`__
extension
Optional PHP extensions: Optional PHP extensions:
- `GD`_ - `GD <http://php.net/manual/en/book.image.php>`__
- `XMLWriter`_ - `XMLWriter <http://php.net/manual/en/book.xmlwriter.php>`__
- `XSL`_ - `XSL <http://php.net/manual/en/book.xsl.php>`__
.. _Zip: http://php.net/manual/en/book.zip.php
.. _XML Parser: http://www.php.net/manual/en/xml.installation.php
.. _GD: http://php.net/manual/en/book.image.php
.. _XMLWriter: http://php.net/manual/en/book.xmlwriter.php
.. _XSL: http://php.net/manual/en/book.xsl.php
Installation Installation
------------ ------------
There are two ways to install PHPWord, i.e. via `Composer`_ or manually There are two ways to install PHPWord, i.e. via
by downloading the library. `Composer <http://getcomposer.org/>`__ or manually by downloading the
library.
Composer Using Composer
~~~~~~~~ ~~~~~~~~~~~~~~
To install via Composer, add the following lines to your To install via Composer, add the following lines to your
``composer.json``: ``composer.json``:
@ -44,25 +41,22 @@ To install via Composer, add the following lines to your
} }
} }
.. _Composer: http://getcomposer.org/ Manual install
~~~~~~~~~~~~~~
Manual installation To install manually, `download PHPWord package from
~~~~~~~~~~~~~~~~~~~ github <https://github.com/PHPOffice/PHPWord/archive/master.zip>`__.
Extract the package and put the contents to your machine. To use the
To install manually, `download PHPWord package from github`_. Extract library, include ``Classes/PHPWord.php`` in your script like below.
the package and put the contents to your machine. To use the library,
include ``Classes/PHPWord.php`` in your script like below.
.. code:: php .. code:: php
require_once '/path/to/PHPWord/Classes/PHPWord.php'; require_once '/path/to/PHPWord/Classes/PHPWord.php';
.. _download PHPWord package from github: https://github.com/PHPOffice/PHPWord/archive/master.zip
Using samples Using samples
------------- -------------
After installation, you can browse and use the samples that weve After installation, you can browse and use the samples that we've
provided, either by command line or using browser. If you can access provided, either by command line or using browser. If you can access
your PHPWord library folder using browser, point your browser to the your PHPWord library folder using browser, point your browser to the
``samples`` folder, e.g. ``http://localhost/PHPWord/samples/``. ``samples`` folder, e.g. ``http://localhost/PHPWord/samples/``.

View File

@ -17,4 +17,8 @@ Example:
$template = $PHPWord->loadTemplate('Template.docx'); $template = $PHPWord->loadTemplate('Template.docx');
$template->setValue('Name', 'Somebody someone'); $template->setValue('Name', 'Somebody someone');
$template->setValue('Street', 'Coming-Undone-Street 32'); $template->setValue('Street', 'Coming-Undone-Street 32');
See ``Sample_07_TemplateCloneRow.php`` for more code sample, including
how to create multirow from a single row in a template by using
``cloneRow``.