利用類別產生XSD檔

產出XSD檔的目的在於提供Word樣板設計之資料框架

在此使用微軟提供之XML Schema Definition Tool (Xsd.exe)工具產生XSD檔

1. 定義類別

01 // 書籍資料
02 public class Book
03 {
04     public string BookId { get; set; }
05     public string Name { get; set; }
06     public string price { get; set; }
07 }
08  
09 // 訂單資料
10 public class Order
11 {
12     public string BuyerName { get; set; }
13     public List<Book> Books { get; set; }
14     public int TotalPrice { get; set; }
15 }

2. 使用Xsd.exe工具產生XSD檔案

工具位置: C:\Program Files (x86)\Microsoft SDKs\Windows\v8.1A\bin\NETFX 4.5.1 Tools

工具語法: xsd D:\Projects\WordGenerator.exe /language:CS /outputdir:d:\Projects\Xsd /type:Order

3. XSD內容如下

01 <?xml version="1.0" encoding="utf-8"?>
02 <xs:schema elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
03   <xs:element name="Order" nillable="true" type="Order" />
04   <xs:complexType name="Order">
05     <xs:sequence>
06       <xs:element minOccurs="0" maxOccurs="1" name="BuyerName" type="xs:string" />
07       <xs:element minOccurs="0" maxOccurs="1" name="Books" type="ArrayOfBook" />
08       <xs:element minOccurs="1" maxOccurs="1" name="TotalPrice" type="xs:int" />
09     </xs:sequence>
10   </xs:complexType>
11   <xs:complexType name="ArrayOfBook">
12     <xs:sequence>
13       <xs:element minOccurs="0" maxOccurs="unbounded" name="Book" nillable="true" type="Book" />
14     </xs:sequence>
15   </xs:complexType>
16   <xs:complexType name="Book">
17     <xs:sequence>
18       <xs:element minOccurs="0" maxOccurs="1" name="BookId" type="xs:string" />
19       <xs:element minOccurs="0" maxOccurs="1" name="Name" type="xs:string" />
20       <xs:element minOccurs="0" maxOccurs="1" name="price" type="xs:string" />
21     </xs:sequence>
22   </xs:complexType>
23 </xs:schema>

4. 加上Namespace

targetNamespace=http://schemas.chris.com/WordGenerator/Order.xsd

xmlns=http://schemas.chris.com/WordGenerator/Order.xsd

利用XSD檔產生特定格式之Word檔

筆者是以Word 2010進行實作,相關實作畫面如下。另外,若使用Word 2013的朋友是無法透過此方法自行定義XML標記的,因為移除自訂 XML 標記是2009年12月22日美國法院的判決結果,購買或取得 Word 2013 授權的客戶會發現此軟體不含特定的自訂 XML 標記實作;所以請使用非Word2013版本來實作此步驟。

http://support.microsoft.com/kb/2761189/zh-tw

1. 加入開發人員工具列

2. 點選開發人員工具列之結構描述

3. 選擇剛產生之XSD檔案

4. 開始編輯畫面與資料關聯

目前希望呈現的樣式(黃色是隨資料異動部分)

點選結構後,產生XML結構工具

圈選Order對應部分後,點選Order

此時會出現選取範圍,就選擇僅套用至選取範圍即可

此時就完成了第一次的資料對應關係

然後依序處理其他部分,結果如下

此時若發現有錯誤發生

調整一下XML選項設定即可

調整完畢後儲存為DOC檔案供下次修改使用

利用特定格式之Word檔產生XSLT檔

1. 下載安裝 Word 2003: XML SDK

http://www.microsoft.com/downloads/details.aspx?familyid=ca83cb4f-8dee-41a3-9c25-dd889aea781c&displaylang=en

2. 將Word檔另存為XML

3. 利用WML2XSLT.exe 將 Order.xml 轉換成 Order.xslt

點選所需的namespace即可

組合資料產生Word檔

資料 + 顯示樣式

= 資料物件序列化(XML) + XSLT

= 產生具有資料及指定樣式Word檔

01 private void CreateWord()
02 {
03  
04     string xsltLocation = @"D:\Order.xslt";
05     string outputPath = @"D:\Order.doc";
06  
07     // Data
08     Order order = new Order()
09     {
10         BuyerName = "Chris Chen",
11         TotalPrice = 600,
12         Books = new List<Book>()
13         {
14             new Book(){BookId="B001", Name="Name01", price="100"},
15             new Book(){BookId="B002", Name="Name02", price="200"},
16             new Book(){BookId="B003", Name="Name03", price="300"},
17         }
18     };
19  
20     // Data XML (一定要namespace)
21     string szInputXml = Serialize(order, "http://schemas.chris.com/WordGenerator/Order.xsd");
22     XmlTextReader xmlReader = new XmlTextReader(new System.IO.StringReader(szInputXml));
23  
24     // XSLT
25     XmlReader xsltReader = XmlReader.Create(xsltLocation);
26  
27     // Create Word
28     byte[] wordDoc = GetWord(xmlReader, xsltReader);
29  
30     // Write resulting array to HDD, show process information
31     using (FileStream fs = new FileStream(outputPath, FileMode.Create))
32         fs.Write(wordDoc, 0, wordDoc.Length);
33  
34     // Display resulting report in Word
35     Process.Start(new ProcessStartInfo(outputPath));
36 }
37  
38 public string Serialize(object obj, string defaultNamespace)
39 {
40     // encoding issue: utf-16 => utf-8
42  
43     XmlSerializer xs = new XmlSerializer(obj.GetType(), defaultNamespace);
44  
45     MemoryStream stream = new MemoryStream();
46     XmlWriterSettings setting = new XmlWriterSettings();
47     setting.Encoding = new UTF8Encoding(false);
48     setting.Indent = true;
49     
50     using (XmlWriter writer = XmlWriter.Create(stream, setting))
51     { xs.Serialize(writer, obj); }
52  
53     return Encoding.UTF8.GetString(stream.ToArray());
54 }
55  
56 public static byte[] GetWord(XmlReader xmlData, XmlReader xsltReader)
57 {
58     XslCompiledTransform xslt = new XslCompiledTransform();
59     XsltArgumentList args = new XsltArgumentList();
60  
61     using (MemoryStream swResult = new MemoryStream())
62     {
63         // Load XSLT to reader and perform transformation
64         xslt.Load(xsltReader);
65         xslt.Transform(xmlData, args, swResult);
66  
67         return swResult.ToArray();
68     }
69 }

結果如同我們所預期的將資料都填入Word檔中

期望效益

1. 開發過程可集中於資料模型的設計(類似ViewModel概念)

2. Word樣式可供客戶自行調整 (不變更資料項目為前提下,僅需自動轉為XSLT檔即可)

3. 資料自動綁定至Word並產生檔案輸出

參考資料

http://www.codeproject.com/Articles/20287/Generating-Word-Reports-Documents

http://msdn.microsoft.com/en-us/library/x6c1kb0s(v=vs.110).aspx

http://blogs.msdn.com/b/williamcornwill/archive/2007/01/17/document-generation-using-wordml-word-2003.aspx

利用XSD配合XSLT產出特定格式Word檔案 -摘自网络的更多相关文章

  1. 第四十二节,configparser特定格式的ini配置文件模块

    configparser用于处理特定格式的文件,其本质上是利用open来操作文件. 特定格式的ini配置文件模块,用于处理ini配置文件,注意:这个ini配置文件,只是ini文件名称的文本文件,不是后 ...

  2. 使用 FOR XML PATH 產生 XML 格式時,遇到 NULL 該如何處理?

    當您嘗試利用 FOR XML PATH 產生 XML 格式時,若遇到 Result Set 為 Null 時,會導致整個查詢結果為 Null ,若您想要在查不到資料時,可以顯示自訂的內容,本文將提供可 ...

  3. JS利用正则配合replace替换指定字符

    替换指定字符的方法有很多,在本文为大家详细介绍下,JS利用正则配合replace是如何做到的,喜欢的朋友可以参考下 定义和用法 replace() 方法用于在字符串中用一些字符替换另一些字符,或替换一 ...

  4. 使用jmeter+ant进行接口自动化测试(数据驱动)之二:利用apache-ant执行测试用例并生成HTML格式测试报告

    在 使用jmeter+ant进行接口自动化测试(数据驱动)之一 介绍了如何使用csv文件来批量管理接口 本次接着介绍如何利用apache-ant执行测试用例并生成HTML格式测试报告 ①下载安装 ap ...

  5. 利用vue-cli配合vue-router搭建一个完整的spa流程

    好文章备忘录: 转自:https://segmentfault.com/a/1190000009160934?_ea=1849098 demo源码:https://github.com/1590123 ...

  6. Microsoft Tech Summit 2018 课程简述:利用 Windows 新特性开发出更好的手绘视频应用

    概述 Microsoft Tech Summit 2018 微软技术暨生态大会将于10月24日至27日在上海世博中心举行,这也会是国内举办的最后一届 Tech Summit,2019 年开始会以 Mi ...

  7. kubernetes 利用label标签来绑定到特定node运行pod

    利用label标签来绑定到特定node运行pod: 不如将有大量I/O的pod部署到配置了ssd的node上或者需要使用GPU的pod部署到某些安装了GPU的节点上 查看节点的标签: kubectl ...

  8. linux中date命令显示昨天的日期信息?以特定格式显示时间?

    需求描述: linux环境中,在使用date命令的时候,可以通过-d指定日期的字符串来显示日期 操作过程: 1.通过date显示昨天的日期 [root@redhat6 ~]# date -d 'yes ...

  9. 请给出如下格式的date命令 例:11-02-26.再给出实现按周输出 比如:周六输出为6,请分别给出命令。

    请给出如下格式的date命令 例:19-01-18.再给出实现按周输出 比如:周六输出为6,请分别给出命令. 解答: 方法1: [root@zhaokang ~]# date2019年 01月 17日 ...

随机推荐

  1. Java 程序检查远程服务器状态

    通常我们以命令的方式判断远程服务器是否正常运行有两种方式,ping 或 telnet 一个远程端口.假设我们要检查的远程服务器都是 Linux 系统. 从 JDK 1.5 以后, InetAddres ...

  2. 【leetcode】Word Break (middle)

    Given a string s and a dictionary of words dict, determine if s can be segmented into a space-separa ...

  3. HDU1412

    大水题.. 求集合的并 /* */ #include<algorithm> #include<iostream> #include<string.h> #inclu ...

  4. Zookeeper + Hadoop + Hbase部署备忘

    网上类似的文章很多,本文只是记录下来备忘.本文分四大步骤: 准备工作.安装zookeeper.安装hadoop.安装hbase,下面分别详细介绍: 一 准备工作 1. 下载 zookeeper.had ...

  5. easyui源码翻译1.32+API翻译全篇导航 (提供下载源码)

    前言 EasyUI每个组件都会有 属性.方法.事件 属性 所有的属性都定义在jQuery.fn.{plugin}.defaults里面.例如,对话框属性定义在jQuery.fn.dialog.defa ...

  6. QT的Paint 系统

    下面对于QT的绘制系统做一个简要说明, 这个系统主要由三部分组成,  QPainter, QPaintDevice, QPaintEngine. QPainter 是一个绘制接口类,提供绘制各种面向用 ...

  7. 【HDOJ】4305 Lightning

    1. 题目描述当一个结点lightning后,可以向其周围距离小于等于R的结点传播lightning.然后以该结点为中心继续传播.以此类推,问最终形成的树形结构有多少个. 2. 基本思路生成树级数模板 ...

  8. linux 用grep匹配横线

    file的内容如下: ADSFADSFSDFASDFJKJK----------------------------------------ADSFADSFSDFASDFJKJK----------- ...

  9. Java版本的删除指定目录及子目录下名叫“xxx.txt”的所有文件

    以前写过一个python版本的,但是在查找文件路径的时候出现错误,无法正确的获取到文件的路径,就造成无法删除该路径下的“xxx.txt”文件. 当时以为是windows版本系统的错误造成这个问题的,也 ...

  10. JavaBean个人总结

    JavaBean在JSP程序中的应用 JavaBean是为Java语言设计的软件组件模型,具有可重复使用和跨平台的特点.可以通过JavaBean来封装业务逻辑,进行数据库操作等,从而很好的实现业务逻辑 ...