Как я могу встроить отформатированный исходный код XML в документы WORD?

7241
eckes

Я пишу документацию с WORD, которая содержит исходный код XML (целые файлы) в качестве примеров. То, как я встраиваю текущий XML, довольно громоздко и не кажется мне реально поддерживаемым:

  • Я заканчиваю редактирование документа в WORD и создаю из него PDF, используя Acrobat
  • затем я открываю свои XML-файлы (2 входных файла, 2 сгенерированных выходных файла) в IE и распечатываю их на принтере PDF, поставляемом Acrobat
  • теперь я открываю Acrobat Pro и прикрепляю четыре файла XML-PDF к своему оригинальному документу.

Проблема с этим рабочим процессом для меня заключается в том, что он требует слишком много ручного труда, чтобы сделать документацию выполненной.

То, что я пробовал до сих пор, не очень удовлетворяет меня:

  • преобразование каждого XML в PDF и добавление их, как описано выше
  • открытие файлов XML с помощью SCiTE, копирование в формате RTF и вставка в Word
  • поэкспериментируя с пакетами LaTeX, чеканками, фрагментами и списками (я мог бы также написать документы с помощью LaTeX), но обнаружил некоторые неразрешимые проблемы в каждом из этих пакетов

Я ищу способ сделать мою документацию более автоматической . Например, встраивание файлов XML, включая форматирование IE (которое я считаю вполне читабельным). Файлы должны быть включены по ссылке, чтобы мне не приходилось вставлять источники XML вручную каждый раз, когда меняется XML.


Редактировать:
Используя превосходный ответ, данный Джереми, я наконец смог установить XSLT, который преобразует данный файл XML в красивый HTML. Мой XSLT основан на исходной таблице стилей IE, но имеет небольшие изменения, так как Word отказывается выполнять динамические вещи, которые необходимы в таблице стилей IE.

В связи с этим я изменил IE XSLT (см. Здесь ), чтобы он больше не нуждался в сценариях (что в моем случае абсолютно не нужно). Для документации: вот таблица стилей:

<?xml version="1.0"?> <!-- IE5 default style sheet, provides a view of any XML document and provides the following features: - color coding of markup - color coding of recognized namespaces - xml, xmlns, xsl, dt  This style sheet is available in IE5 in a compact form at the URL "res://msxml.dll/DEFAULTSS.xsl". This version differs only in the addition of comments and whitespace for readability.  Author: Jonathan Marsh () Modified: 05/21/2001 by Nate Austin () Converted to use XSLT rather than WD-xsl -->  <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:dt="urn:schemas-microsoft-com:datatypes" xmlns:d2="uuid:C2F41010-65B3-11d1-A29F-00AA00C14882"> <xsl:strip-space elements="*"/> <xsl:output method="html"/> <xsl:template match="/"> <HTML> <HEAD> <STYLE> BODY  <!-- tag --> .t  <!-- attribute names --> .an  <!-- tag in xsl namespace --> .xt  <!-- attribute in xml or xmlns namespace --> .ns  <!-- attribute in dt namespace --> .dt  <!-- markup characters --> .m  <!-- text node --> .tx  <!-- single-line (inline) cdata --> .di {} <!-- DOCTYPE declaration --> .d  <!-- pi --> .pi  <!-- single-line (inline) comment --> .ci  </STYLE> </HEAD> <BODY class="st"> <xsl:apply-templates> <xsl:with-param name="depth">0</xsl:with-param> </xsl:apply-templates> </BODY> </HTML> </xsl:template>  <!-- decides whether we have a tag in an xsl namespace or a regular tag --> <xsl:template name="classwriter"> <xsl:param name="curname"/> <SPAN> <xsl:attribute name="class"><xsl:if test="starts-with($curname,'xsl:')">x</xsl:if>t</xsl:attribute> <xsl:value-of select="$curname"/> </SPAN> </xsl:template>  <!-- Helper that does the indent --> <xsl:template name="indent"> <xsl:param name="depth"/> <xsl:if test="$depth &gt; 0"> <xsl:text>&#160;&#160;</xsl:text> <xsl:call-template name="indent"> <xsl:with-param name="depth" select="$depth - 1"/> </xsl:call-template> </xsl:if> </xsl:template>  <!-- Template for pis not handled elsewhere --> <xsl:template match="processing-instruction()"> <DIV class="e"> <SPAN class="m">&lt;?</SPAN> <SPAN class="pi"> <xsl:value-of select="name()"/>&#160;<xsl:value-of select="."/> </SPAN> <SPAN class="m">?&gt;</SPAN> </DIV> </xsl:template>  <!-- Template for attributes not handled elsewhere --> <xsl:template match="@*"> <SPAN class="an">&#160;<xsl:value-of select="name()"/></SPAN><SPAN class="m">="</SPAN><B><xsl:value-of select="."/></B><SPAN class="m">"</SPAN> </xsl:template>  <!-- Template for text nodes --> <xsl:template match="text()"> <DIV class="e"> <SPAN class="tx"> <xsl:value-of select="."/> </SPAN> </DIV> </xsl:template>   <!-- Note that in the following templates for comments and cdata, by default we apply a style appropriate for single line content (e.g. non-expandable, single line display). But we also inject the attribute 'id="clean"' and a script call 'f(clean)'. As the output is read by the browser, it executes the function immediately. The function checks to see if the comment or cdata has multi-line data, in which case it changes the style to a expandable, multi-line display. Performing this switch in the DHTML instead of from script in the XSL increases the performance of the style sheet, especially in the browser's asynchronous case -->  <!-- Template for comment nodes --> <xsl:template match="comment()"> <xsl:param name="depth"/> <DIV class="k"> <SPAN> <SPAN class="m"> <xsl:call-template name="indent"> <xsl:with-param name="depth" select="$depth"/> </xsl:call-template> &lt;!-- </SPAN> </SPAN> <SPAN class="ci"> <xsl:value-of select="."/> </SPAN> <SPAN class="m">--&gt;</SPAN> </DIV> </xsl:template>  <!-- Note the following templates for elements may examine children. This harms to some extent the ability to process a document asynchronously - we can't process an element until we have read and examined at least some of its children. Specifically, the first element child must be read before any template can be chosen. And any element that does not have element children must be read completely before the correct template can be chosen. This seems an acceptable performance loss in the light of the formatting possibilities available when examining children. -->  <!-- Template for elements not handled elsewhere (leaf nodes) --> <xsl:template match="*"> <xsl:param name="depth"/> <DIV class="e"> <xsl:call-template name="indent"> <xsl:with-param name="depth" select="$depth"/> </xsl:call-template> <SPAN class="m">&lt;</SPAN> <xsl:call-template name="classwriter"><xsl:with-param name="curname" select="name()"/></xsl:call-template> <xsl:apply-templates select="@*"/> <SPAN class="m"> /&gt;</SPAN> </DIV> </xsl:template>  <!-- Template for elements with comment, pi and/or cdata children --> <xsl:template match="*[comment() | processing-instruction()]"> <xsl:param name="depth"/> <DIV class="e"> <SPAN class="m">&lt;</SPAN> <xsl:call-template name="classwriter"><xsl:with-param name="curname" select="name()"/></xsl:call-template> <xsl:apply-templates select="@*"> <xsl:with-param name="depth" select="$depth + 1"/> </xsl:apply-templates> <SPAN class="m">&gt;</SPAN> <DIV> <xsl:apply-templates> <xsl:with-param name="depth" select="$depth + 1"/> </xsl:apply-templates> <DIV> <SPAN class="m">&lt;/</SPAN> <xsl:call-template name="classwriter"><xsl:with-param name="curname" select="name()"/></xsl:call-template> <SPAN class="m">&gt;</SPAN> </DIV> </DIV> </DIV> </xsl:template>  <!-- Template for elements with only text children --> <xsl:template match="*[text() and not(comment() | processing-instruction())]"> <xsl:param name="depth"/> <DIV class="e"> <!-- write the starting tag --> <xsl:call-template name="indent"> <xsl:with-param name="depth" select="$depth"/> </xsl:call-template> <SPAN class="m">&lt;</SPAN> <xsl:call-template name="classwriter"><xsl:with-param name="curname" select="name()"/></xsl:call-template> <xsl:apply-templates select="@*"> <xsl:with-param name="depth" select="$depth + 1"/> </xsl:apply-templates> <SPAN class="m">&gt;</SPAN> <!-- write the tag content --> <SPAN class="tx"> <xsl:value-of select="."/> </SPAN> <!-- write the end tag --> <SPAN class="m">&lt;/</SPAN> <xsl:call-template name="classwriter"><xsl:with-param name="curname" select="name()"/></xsl:call-template> <SPAN class="m">&gt;</SPAN> </DIV> </xsl:template>  <!-- Template for elements with element children --> <xsl:template match="*[*]"> <xsl:param name="depth"/> <DIV class="e"> <xsl:call-template name="indent"> <xsl:with-param name="depth" select="$depth"/> </xsl:call-template> <SPAN class="m">&lt;</SPAN> <xsl:call-template name="classwriter"><xsl:with-param name="curname" select="name()"/></xsl:call-template> <xsl:apply-templates select="@*" /> <SPAN class="m">&gt;</SPAN> <DIV> <xsl:apply-templates> <xsl:with-param name="depth" select="$depth + 1"/> </xsl:apply-templates> <DIV> <xsl:call-template name="indent"> <xsl:with-param name="depth" select="$depth"/> </xsl:call-template> <SPAN class="m">&lt;/</SPAN> <xsl:call-template name="classwriter"><xsl:with-param name="curname" select="name()"/></xsl:call-template> <SPAN class="m">&gt;</SPAN> </DIV> </DIV> </DIV> </xsl:template>  <xsl:template match="text()" /> </xsl:stylesheet> 
3

1 ответ на вопрос

3
Jeremy W

Вы можете сделать это, вставив поле INCLUDETEXT в ваш документ Word


  • Получите или создайте XSL-преобразование, которое выводит действительный WordPressingML (Word 2003, 2007). Я нашел один, который выглядит так, как будто он может быть использован IE здесьC:\Windows\SysWOW64\wbem\en-US\xml.xsl

  • Вставьте поле INCLUDETEXT, например так:

    { INCLUDETEXT "c:\\a\\myxml.xml" \t c:\\a\\myxml.xsl \c xml }

Когда ваш исходный XML-файл изменится, вам потребуется обновить каждое поле INCLUDETEXT (выделите его и нажмите F3) или добавить несколько VBA, чтобы обновить поля при загрузке документа.

+1 это круто! какие-нибудь подсказки, как сделать правильные отступы? eckes 12 лет назад 0
Это [руководство по созданию универсального xslt pretty-print для источника xml] (http://www.xml.com/lpt/a/1681) выглядит полезным. В конце есть полный файл xsl. Jeremy W 12 лет назад 0
еще более круто! щедрость будет твоей! eckes 12 лет назад 0

Похожие вопросы