2017 © Pedro Peláez
 

library docxtemplates

Merge data into .docx templates in a similar fashion to mailmerge

image

snicholson/docxtemplates

Merge data into .docx templates in a similar fashion to mailmerge

  • Saturday, August 8, 2015
  • by SamNicholson
  • Repository
  • 1 Watchers
  • 2 Stars
  • 87 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 1 Forks
  • 0 Open issues
  • 2 Versions
  • 0 % Grown

The README.md

PHPDocxTemplates

A PHP Library For Using Docx Files As Fillable Templates, (*1)

Installation

Can be installed via composer, simply require the following -, (*2)

``` javascript require: "snicholson/docxtemplates": "dev-master", (*3)


## Usage Using PHPDocxTemplates is simple, to run a merge on a document, you first need to define a rule collection. This is done in the following fashion, rules are a target/data combination. Target is the string to be replaced, and data is the value to replace it. You can perform a SimpleMerge using the below class (in namepsace SNicholson/PHPDocXTemplate), you need to provide it with the filepath to your template, and a filepath for the output file, it will save it in place for you. The below is an example of Simple merge using only simple rules - <br> ``` php $ruleCollection = new RuleCollection(); $ruleTarget = '#texttoreplace#'; $ruleData = function(){ return 'a test value from a closure'; }; $ruleCollection->addSimpleRule($ruleTarget,$ruleData); $ruleCollection->addSimpleRule('#someMoreTextToReplace#','Some text that needs replacing!'); DocXTemplate::merge('input.docx','output.docx',$ruleCollection);

Simple Rules

A simple rule is a simple string replace, the target is the string to be replaced, and the data is either a string or closure to replace it with, SimpleRules are added to Rule Collections as in the example below, (*4)

``` php, (*5)

$ruleCollection = new RuleCollection(); $ruleTarget = '#texttoreplace#'; $ruleData = function(){ return 'a test value from a closure'; }; $ruleCollection->addSimpleRule($ruleTarget,$ruleData); $ruleCollection->addSimpleRule( '#someMoreTextToReplace#', 'Some text that needs replacing!' );, (*6)


### Regexp Rules Regular Expression rules are slightly more advanced, they allow you to specify a regular expression to match, receive matches in a closure and act on their values accordingly - <br> ``` php $ruleCollection = new RuleCollection(); $ruleTarget = '/ARegularExpression/'; $ruleData = function($match){ //I can perform logic on the $match value in here return substr($match,0,3); };o $ruleCollection->addRegexpRule($ruleTarget,$ruleData);

Merging RuleCollections into Word Documents

Merging can be done simply using the Static simpleMerge class, it is intended to add more advanced merge Classes in the future. You must provide an inbound filepath and an outbound filepath, along with a RuleCollection. The outbound filepath needs to be writable to PHP., (*7)

php DocXTemplate::merge('input.docx','output.docx',$ruleCollection);, (*8)

TODO

Outstanding
- Be able to replace text with images
- Be able to generate an insert tables in place of text
- Support Basic formatting (bold, italic, line returns) from HTML input to the XML format, (*9)

The Versions

08/08 2015

dev-master

9999999-dev

Merge data into .docx templates in a similar fashion to mailmerge

  Sources   Download

The Requires

  • php >=5.4.0

 

The Development Requires

08/08 2015

1.1

1.1.0.0

Merge data into .docx templates in a similar fashion to mailmerge

  Sources   Download

The Requires

  • php >=5.4.0

 

The Development Requires