0

我正在开发一项功能,用户可以使用该功能上传带有占位符的 docx 文档。这些占位符稍后将被数据库中的数据替换。为了确保用户只使用预定义的占位符,他必须选择一个 Ms Access 文件 (.mdb),其定义的字段 (mergefield) 是有效的占位符。我成功地用我的数据替换了合并字段。但是,我无法摆脱与 Access 文件的定义关系。我知道必须从我的 docx 文档的 xml 中删除以下内容:

<pkg:part pkg:name="/word/_rels/settings.xml.rels" pkg:contentType="application/vnd.openxmlformats-package.relationships+xml"><pkg:xmlData>
<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships"><Relationship Id="rId2" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/recipientData" Target="recipientData.xml"/>
<Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/mailMergeSource" Target="file:///D:\Downloads\Lager.mdb" TargetMode="External"/></Relationships></pkg:xmlData></pkg:part>


<w:mailMerge><w:mainDocumentType w:val="formLetters"/><w:linkToQuery/><w:dataType w:val="native"/><w:connectString w:val="Provider=Microsoft.ACE.OLEDB.12.0;User ID=Admin;Data Source=P:\SINA\Projektteam\Referat413\Basisklassen fuer Schablonen\Lager.mdb;Mode=Read;Extended Properties=&quot;&quot;;Jet OLEDB:System database=&quot;&quot;;Jet OLEDB:Registry Path=&quot;&quot;;Jet OLEDB:Engine Type=6;Jet OLEDB:Database Locking Mode=0;Jet OLEDB:Global Partial Bulk Ops=2;Jet OLEDB:Global Bulk Transactions=1;Jet OLEDB:New Database Password=&quot;&quot;;Jet OLEDB:Create System Database=False;Jet OLEDB:Encrypt Database=False;Jet OLEDB:Don't Copy Locale on Compact=False;Jet OLEDB:Compact Without Replica Repair=False;Jet OLEDB:SFP=False;Jet OLEDB:Support Complex Data=False"/><w:query w:val="SELECT * FROM `Office Address List` "/><w:odso><w:udl w:val="Provider=Microsoft.ACE.OLEDB.12.0;User ID=Admin;Data Source=D:\Benutzer-Profile\boehmv\Downloads\Lager.mdb;Mode=Read;Extended Properties=&quot;&quot;;Jet OLEDB:System database=&quot;&quot;;Jet OLEDB:Registry Path=&quot;&quot;;Jet OLEDB:Engine Type=6;Jet OLEDB:Database Locking Mode=0;Jet OLEDB:Global Partial Bulk Ops=2;Jet OLEDB:Global Bulk Transactions=1;Jet OLEDB:New Database Password=&quot;&quot;;Jet OLEDB:Create System Database=False;Jet OLEDB:Encrypt Database=False;Jet OLEDB:Don't Copy Locale on Compact=False;Jet OLEDB:Compact Without Replica Repair=False;Jet OLEDB:SFP=False;Jet OLEDB:Support Complex Data=False;Jet OLEDB:Bypass UserInfo Validation=False"/>
<w:table w:val="Office Address List"/>
<w:src r:id="rId1"/><w:colDelim w:val="9"/><w:type w:val="addressBook"/><w:fHdr/><w:fieldMapData><w:column w:val="0"/><w:lid w:val="de-DE"/></w:fieldMapData><w:fieldMapData><w:column w:val="0"/><w:lid w:val="de-DE"/></w:fieldMapData><w:fieldMapData><w:column w:val="0"/><w:lid w:val="de-DE"/></w:fieldMapData><w:fieldMapData><w:column w:val="0"/><w:lid w:val="de-DE"/></w:fieldMapData><w:fieldMapData><w:column w:val="0"/><w:lid w:val="de-DE"/></w:fieldMapData><w:recipientData r:id="rId2"/></w:odso>
</w:mailMerge>

知道如何用 docx4j 解决这个问题吗?我通过以下方法找到了 w:mailMerge-tag:

String xml = XmlUtils.marshaltoString(wordMLPackage.getMainDocumentPart().getDocumentSettingsPart().getJaxbElement(), true, true);

不幸的是,我无法更改 DocumentSettingsPart。

4

1 回答 1

0

我终于找到了一种适合我的方法。以下方法删除邮件合并设置:

private void removeMailmergeRelationship(WordprocessingMLPackage wordMLPackage) {
    DocumentSettingsPart dsp = wordMLPackage.getMainDocumentPart().getDocumentSettingsPart();
    CTSettings settings = dsp.getJaxbElement();
    settings.setMailMerge(null);
}
于 2013-11-18T14:44:14.467 回答