利用類別產生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. eclipse颜色配置

    Eclipse颜色主题插件:Eclipse Color Theme http://blog.sina.com.cn/s/blog_674212810101go8x.html 一个很赞的eclipse插 ...

  2. python参考手册--第3章类型和对象

    1.对象的身份.类型.值 (1)身份:对象在内存中位置的指针,地址值, >>> a = [1,2,3,4,5] >>> id(a)48497328 >> ...

  3. 将ANGULAR与后端请求结合

    简单的结合,却是很多应用的基础.RESTFUL就此而生.瘦服务,富客户. <!DOCTYPE html> <html lang="en" ng-app=" ...

  4. linux cd命令不带路径参数

    #切换到当前用户的主目录.若为root用户,则切换到/root,若普通用户,则切换到/home/username $ cd

  5. Redis hash数据类型操作

    Redis hash是一个string类型的field和value的映射表.一个key可对应多个field,一个field对应一个value.将一个对象存储 为hash类型,较于每个字段都存储成str ...

  6. mac 用 brew

    mac 下用   brew 安装插件, 有重复的不会再次安装,比xmap模式好

  7. MSSQL复制功能实现与Oracle数据库同步

    1.分别建立链接对数据库进行操作,SQLServer可以用ADO.NET,操作Oracle可以用OLEDB或者用System.Data.OracleClient(需要添加引用才能用) 这种方案的优点就 ...

  8. E-BOM和M-BOM的区别

    简单一点,ENG BOM一般用于试产,正式BOM一般用于量产:ENG BOM是FOR RD设计用的.即TEMP档.并非正式区的.一般的电子零件类的企业都会用到ENG BOM.在EBS中,ENG BOM ...

  9. Android学习Service中遇到的问题

    今天学习service,然后遇到了一个force close,log中存在这个一句话: 05-23 14:13:26.408: E/AndroidRuntime(17616): android.con ...

  10. 1019.Line Painting(线段树 离散化)

    1019 离散化都忘记怎么写了 注意两个端点 离散化后用线段树更新区间 混色为-1  黑为2  白为1  因为N不大 最后直接循环标记这一段的颜色查找 #include <iostream> ...