C# 开源组件--Word操作组件DocX
使用模版生成简历
下面将以一个简历实例来讲解DocX对表格的操作,先看看生成的效果

private static void CreateResume()
{
DocX doc;
try
{
doc = DocX.Load(@"ResumeTemplate.docx");
//给域赋值
if (doc.Tables != null && doc.Tables.Count > )
{
Table table=doc.Tables[];
//姓名
table.Rows[].Cells[].Paragraphs[].Append("DocX");
//姓名
table.Rows[].Cells[].Paragraphs[].Append("未婚"); //出生
table.Rows[].Cells[].Paragraphs[].Append("2010-09-19");
//政治面貌
table.Rows[].Cells[].Paragraphs[].Append("团员"); //性别
table.Rows[].Cells[].Paragraphs[].Append("男");
//民族
table.Rows[].Cells[].Paragraphs[].Append("汉族"); //学位
table.Rows[].Cells[].Paragraphs[].Append("大学本科");
//移动电话
table.Rows[].Cells[].Paragraphs[].Append(""); //专业
table.Rows[].Cells[].Paragraphs[].Append("软件工程");
//邮箱
table.Rows[].Cells[].Paragraphs[].Append("2345678@qq.com"); //地址
table.Rows[].Cells[].Paragraphs[].Append("故宫"); //照片
Novacode.Image image = doc.AddImage(@"logo.jpg");
Picture picture = image.CreatePicture();
table.Rows[].Cells[].InsertParagraph().AppendPicture(picture); //教育背景
table.Rows[].Cells[].Paragraphs[].Append("2011-2013");
table.Rows[].Cells[].Paragraphs[].Append("小学"); //主修课程
table.Rows[].Cells[].Paragraphs[].Append("数据结构,C语言,算法,C++"); //个人能力
table.Rows[].Cells[].Paragraphs[].Append("熟练掌握DocX操作Word,SQL能力强悍"); //计算机能力
table.Rows[].Cells[].Paragraphs[].Append("高级软件工程师"); //外语水平
table.Rows[].Cells[].Paragraphs[].Append("CET-4,CET-6"); //奖励情况
table.Rows[].Cells[].Paragraphs[].Append("1999年几月 曾获优秀班干部,3等奖学金1999年几月 曾获校优秀干部,学生会先进集体,2等奖学金20**年几月 曾获优秀学习委员,网络技术协会负责人,……………………"); //自我评价
table.Rows[].Cells[].Paragraphs[].Append("本人性格开朗、稳重、有活力,待人热情、真诚;工作认真负责,积极主动,能吃苦耐劳,用于承受压力,勇于创新;有很强的组织能力和团队协作精神,具有较强的适应能力;纪律性强,工作积极配合;意志坚强,具有较强的无私奉献精神。"); }
doc.SaveAs(@"DocXResume.docx");
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
}
读写表格数据
上面的例子是想表格中写入数据,那么读取数据的操作可以类比出来,也是很简单的这里就不多介绍了,工具里面创建表格写入数据的代码贴出来,供大家参考。
/// <summary>
/// 根据读取的表信息导出WORD文档
/// </summary>
/// <param name="list">表信息集合</param>
/// <param name="strExportPath">导出路径</param>
public static void CreateWord(List<TableInfo> list, string strExportPath, BackgroundWorker bw)
{
int fontSize = ;
using (DocX doc = DocX.Create(strExportPath, DocumentTypes.Document))
{
int proc = ;
foreach (TableInfo t in list)
{
Paragraph p1 = doc.InsertParagraph();
p1.AppendLine(string.IsNullOrEmpty(t.Name) ? t.Code : t.Name + "\n").Bold(); Table table = doc.AddTable(t.ListColumnInfo.Count + , );
table.Design = TableDesign.TableGrid;
table.Alignment = Alignment.center; List<Row> rows = table.Rows;
Row row0 = rows[];
row0.MergeCells(, );
row0.Cells[].Paragraphs[].Append("数据表中文名称").FontSize(fontSize);
row0.MergeCells(, );
row0.Cells[].Paragraphs[].Append(t.Name).FontSize(fontSize);
row0.MergeCells(, );
row0.Cells[].Paragraphs[].Append("修改说明").FontSize(fontSize);
row0.MergeCells(, );
row0.Cells[].Paragraphs[].Append(t.IsUpdate ? "调整" : "新增").FontSize(fontSize).Color(t.IsUpdate ? Color.Red : Color.Blue); row0.Cells[].Width = ;
row0.Cells[].Width = ;
row0.Cells[].Width = ;
row0.Cells[].Width = ;
row0.Height = ; Row row1 = rows[];
row1.MergeCells(, );
row1.Cells[].Paragraphs[].Append("数据表英文名称").FontSize(fontSize);
row1.MergeCells(, );
row1.Cells[].Paragraphs[].Append(t.Code).FontSize(fontSize);
row1.Cells[].Width = ;
row1.Cells[].Width = ;
row1.Height = ; Row row2 = rows[];
row2.MergeCells(, );
row2.Cells[].Paragraphs[].Append("功能简述").FontSize(fontSize);
row2.MergeCells(, );
row2.Cells[].Paragraphs[].Append("").FontSize(fontSize);
row2.Cells[].Width = ;
row2.Cells[].Width = ;
row2.Height = ; Row row3 = rows[];
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].Width = ;
row3.Cells[].Width = ;
row3.Cells[].Width = ;
row3.Cells[].Width = ;
row3.Cells[].Width = ;
row3.Cells[].Width = ;
row3.Cells[].Width = ;
row3.Cells[].Width = ;
row3.Cells[].Width = ;
row3.Cells[].Width = ;
row3.Cells[].Width = ; row3.Cells[].Paragraphs[].Append("序号").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("字段中文名").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("字段英文名").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("数据类型").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("宽度").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("约束").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("默认值").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("空值").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("枚举&说明").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("自增").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("修改说明").Bold().FontSize(fontSize); Row row = null;
ColumnInfo info = null;
for (int i = ; i < t.ListColumnInfo.Count; i++)
{
row = rows[i + ];
info = t.ListColumnInfo[i];
row.Cells[].Paragraphs[].Append(info.Sequence.ToString()).FontSize(fontSize);
row.Cells[].Paragraphs[].Append(info.Name).FontSize(fontSize);
row.Cells[].Paragraphs[].Append(info.Code).FontSize(fontSize);
row.Cells[].Paragraphs[].Append(info.DataType).FontSize(fontSize);
row.Cells[].Paragraphs[].Append(info.Width).FontSize(fontSize);
row.Cells[].Paragraphs[].Append(info.PK ? "PK" : "").FontSize(fontSize);
row.Cells[].Paragraphs[].Append(info.DefaultValue).FontSize(fontSize);
row.Cells[].Paragraphs[].Append(info.Nullable ? "" : "N").FontSize(fontSize);
row.Cells[].Paragraphs[].Append("").FontSize(fontSize);
row.Cells[].Paragraphs[].Append(info.Identity ? "Y" : "").FontSize(fontSize);
row.Cells[].Paragraphs[].Append("").FontSize(fontSize); row.Cells[].Width = ;
row.Cells[].Width = ;
row.Cells[].Width = ;
row.Cells[].Width = ;
row.Cells[].Width = ;
row.Cells[].Width = ;
row.Cells[].Width = ;
row.Cells[].Width = ;
row.Cells[].Width = ;
row.Cells[].Width = ;
row.Cells[].Width = ; row.Height = ;
}
p1.InsertTableAfterSelf(table);
bw.ReportProgress(proc * / list.Count, "Process");
proc++;
}
doc.Save();
}
}/// <summary>
/// 根据读取的表信息导出WORD文档
/// </summary>
/// <param name="list">表信息集合</param>
/// <param name="strExportPath">导出路径</param>
public static void CreateWord(List<TableInfo> list, string strExportPath, BackgroundWorker bw)
{
int fontSize = ;
using (DocX doc = DocX.Create(strExportPath, DocumentTypes.Document))
{
int proc = ;
foreach (TableInfo t in list)
{
Paragraph p1 = doc.InsertParagraph();
p1.AppendLine(string.IsNullOrEmpty(t.Name) ? t.Code : t.Name + "\n").Bold(); Table table = doc.AddTable(t.ListColumnInfo.Count + , );
table.Design = TableDesign.TableGrid;
table.Alignment = Alignment.center; List<Row> rows = table.Rows;
Row row0 = rows[];
row0.MergeCells(, );
row0.Cells[].Paragraphs[].Append("数据表中文名称").FontSize(fontSize);
row0.MergeCells(, );
row0.Cells[].Paragraphs[].Append(t.Name).FontSize(fontSize);
row0.MergeCells(, );
row0.Cells[].Paragraphs[].Append("修改说明").FontSize(fontSize);
row0.MergeCells(, );
row0.Cells[].Paragraphs[].Append(t.IsUpdate ? "调整" : "新增").FontSize(fontSize).Color(t.IsUpdate ? Color.Red : Color.Blue); row0.Cells[].Width = ;
row0.Cells[].Width = ;
row0.Cells[].Width = ;
row0.Cells[].Width = ;
row0.Height = ; Row row1 = rows[];
row1.MergeCells(, );
row1.Cells[].Paragraphs[].Append("数据表英文名称").FontSize(fontSize);
row1.MergeCells(, );
row1.Cells[].Paragraphs[].Append(t.Code).FontSize(fontSize);
row1.Cells[].Width = ;
row1.Cells[].Width = ;
row1.Height = ; Row row2 = rows[];
row2.MergeCells(, );
row2.Cells[].Paragraphs[].Append("功能简述").FontSize(fontSize);
row2.MergeCells(, );
row2.Cells[].Paragraphs[].Append("").FontSize(fontSize);
row2.Cells[].Width = ;
row2.Cells[].Width = ;
row2.Height = ; Row row3 = rows[];
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].FillColor = Color.FromArgb(, , );
row3.Cells[].Width = ;
row3.Cells[].Width = ;
row3.Cells[].Width = ;
row3.Cells[].Width = ;
row3.Cells[].Width = ;
row3.Cells[].Width = ;
row3.Cells[].Width = ;
row3.Cells[].Width = ;
row3.Cells[].Width = ;
row3.Cells[].Width = ;
row3.Cells[].Width = ; row3.Cells[].Paragraphs[].Append("序号").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("字段中文名").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("字段英文名").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("数据类型").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("宽度").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("约束").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("默认值").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("空值").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("枚举&说明").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("自增").Bold().FontSize(fontSize);
row3.Cells[].Paragraphs[].Append("修改说明").Bold().FontSize(fontSize); Row row = null;
ColumnInfo info = null;
for (int i = ; i < t.ListColumnInfo.Count; i++)
{
row = rows[i + ];
info = t.ListColumnInfo[i];
row.Cells[].Paragraphs[].Append(info.Sequence.ToString()).FontSize(fontSize);
row.Cells[].Paragraphs[].Append(info.Name).FontSize(fontSize);
row.Cells[].Paragraphs[].Append(info.Code).FontSize(fontSize);
row.Cells[].Paragraphs[].Append(info.DataType).FontSize(fontSize);
row.Cells[].Paragraphs[].Append(info.Width).FontSize(fontSize);
row.Cells[].Paragraphs[].Append(info.PK ? "PK" : "").FontSize(fontSize);
row.Cells[].Paragraphs[].Append(info.DefaultValue).FontSize(fontSize);
row.Cells[].Paragraphs[].Append(info.Nullable ? "" : "N").FontSize(fontSize);
row.Cells[].Paragraphs[].Append("").FontSize(fontSize);
row.Cells[].Paragraphs[].Append(info.Identity ? "Y" : "").FontSize(fontSize);
row.Cells[].Paragraphs[].Append("").FontSize(fontSize); row.Cells[].Width = ;
row.Cells[].Width = ;
row.Cells[].Width = ;
row.Cells[].Width = ;
row.Cells[].Width = ;
row.Cells[].Width = ;
row.Cells[].Width = ;
row.Cells[].Width = ;
row.Cells[].Width = ;
row.Cells[].Width = ;
row.Cells[].Width = ; row.Height = ;
}
p1.InsertTableAfterSelf(table);
bw.ReportProgress(proc * / list.Count, "Process");
proc++;
}
doc.Save();
}
}
合并单元格
DocX使用MergeCells方法就可以合并单元格了
List<Row> rows = table.Rows;
Row row0 = rows[];
row0.MergeCells(, );
row0.Cells[].Paragraphs[].Append("数据表中文名称").FontSize(fontSize);
row0.MergeCells(, );
row0.Cells[].Paragraphs[].Append(t.Name).FontSize(fontSize);
row0.MergeCells(, );
row0.Cells[].Paragraphs[].Append("修改说明").FontSize(fontSize);
row0.MergeCells(, );
row0.Cells[].Paragraphs[].Append(t.IsUpdate ? "调整" : "新增").FontSize(fontSize).Color(t.IsUpdate ? Color.Red : Color.Blue);
本人转自:http://www.cnblogs.com/yanweidie/p/3861482.html#_label2
C# 开源组件--Word操作组件DocX的更多相关文章
- 开源word操作组件DocX的记录
开源word操作组件DocX的记录 使用开源word操作组件DocX的记录 1.DocX简介 1.1 简介 DocX是一个在不需要安装word的情况下对word进行操作的开源轻量级.net组件,是由爱 ...
- DocX开源WORD操作组件的学习系列四
DocX学习系列 DocX开源WORD操作组件的学习系列一 : http://www.cnblogs.com/zhaojiedi1992/p/zhaojiedi_sharp_001_docx1.htm ...
- DocX开源WORD操作组件的学习系列三
DocX学习系列 DocX开源WORD操作组件的学习系列一 : http://www.cnblogs.com/zhaojiedi1992/p/zhaojiedi_sharp_001_docx1.htm ...
- DocX开源WORD操作组件的学习系列二
DocX学习系列 DocX开源WORD操作组件的学习系列一 : http://www.cnblogs.com/zhaojiedi1992/p/zhaojiedi_sharp_001_docx1.htm ...
- DocX开源WORD操作组件的学习系列一
DocX学习系列 DocX开源WORD操作组件的学习系列一 : http://www.cnblogs.com/zhaojiedi1992/p/zhaojiedi_sharp_001_docx1.htm ...
- [.NET] 开头不讲"Hello Word",读尽诗书也枉然 : Word 操作组件介绍 - Spire.Doc
开头不讲"Hello Word",读尽诗书也枉然 : Word 操作组件介绍 - Spire.Doc [博主]反骨仔 [原文地址]http://www.cnblogs.com/li ...
- 使用开源word操作组件DocX的记录
1.DocX简介 1.1 简介 DocX是一个在不需要安装word的情况下对word进行操作的开源轻量级.net组件,是由爱尔兰的一个叫Cathal Coffey的博士生开发出来的.DocX使得操作w ...
- .Net开源Excel、Word操作组件-NPOI、EPPlus、DocX[转]
link: http://www.cnblogs.com/jacktang/p/4493760.html 一.NPOI 简介:NPOI is the .NET version of POI Java ...
- .Net开源Excel、Word操作组件-NPOI、EPPlus、DocX
一.NPOI 简介: NPOI is the .NET version of POI Java project. With NPOI, you can read/write Office 2003/2 ...
随机推荐
- Json数组追加数据
背景:在做一个购物车的时候,点击第一个商品,然后存入一个json数组中,点击第二个商品的时候,又继续在json数组中追加,代码如下: <script type="text/javasc ...
- IE8下String的Trim()方法失效的解决方案
简洁方便 用jquery的trim()方法,$.trim(str)就可以了.
- postgres索引创建、 存储过程的创建以及在c#中的调用
postgres创建索引参考 http://www.cnblogs.com/stephen-liu74/archive/2012/05/09/2298182.html CREATE TABLE tes ...
- Lintcode 150.买卖股票的最佳时机 II
------------------------------------------------------------ 卧槽竟然连题意都没看懂,百度了才明白题目在说啥....我好方啊....o(╯□ ...
- 关于QImage提取单色通道方法(vector)
转载请标明处: 作者:微微苏荷 本文地址:关于QImage提取单色通道方法(vector) 近日,用QT和mxnet结合做一个图像识别的demo.遇到需要把图片从QImage转为vector单色分离的 ...
- 【Java EE 学习 74 下】【数据采集系统第六天】【使用Jfreechart的统计图实现】【将JFreechart整合到项目中】
之前说了JFreechart的基本使用方法,包括生成饼图.柱状统计图和折线统计图的方法.现在需要将其整合到数据采集系统中根据调查结果生成三种不同的统计图. 一.统计模型的分析和设计 实现统计图显示的流 ...
- Hadoop单机模式安装-(2)安装Ubuntu虚拟机
网络上关于如何单机模式安装Hadoop的文章很多,按照其步骤走下来多数都失败,按照其操作弯路走过了不少但终究还是把问题都解决了,所以顺便自己详细记录下完整的安装过程. 此篇主要介绍在虚拟机设置完毕后, ...
- C++ 系列:socket 资料收集
Copyright © 1900-2016, NORYES, All Rights Reserved. http://www.cnblogs.com/noryes/ 欢迎转载,请保留此版权声明. -- ...
- 进击的Python【第二十章】
1.Django请求的生命周期 路由系统 -> 试图函数(获取模板+数据=>渲染) -> 字符串返回给用户 2.路由系统 /index/ -> 函数或类.as_view() / ...
- eclipse的maven项目,如何使用java run main函数
项目使用maven管理,一般说来就使用jetty:run了.但是对于做功能测试和集成测试的用例,需要使用自定义的quickrun来运行进行测试环境的参数设定和功能隔离,google一番发现maven有 ...