snicholson / docxtemplates
Merge data into .docx templates in a similar fashion to mailmerge
Installs: 7 426
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 1
Forks: 2
Open Issues: 0
Requires
- php: >=5.4.0
Requires (Dev)
- phpunit/phpunit: 4.5.*
This package is auto-updated.
Last update: 2025-05-28 17:38:21 UTC
README
A PHP Library For Using Docx Files As Fillable Templates
Installation
Can be installed via composer, simply require the following -
require: "snicholson/docxtemplates": "dev-master"
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 -
$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
$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!' );
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 -
$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.
DocXTemplate::merge('input.docx','output.docx',$ruleCollection);
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