一、创建表格操作

private void btnExport_Click(object sender, EventArgs e)
{
var dbcontext = new BlogModel();
var list = dbcontext.ArticleInfos.ToList();
//创建document对象
XWPFDocument doc = new XWPFDocument();
//创建段落对象
XWPFParagraph p1 = doc.CreateParagraph();
//创建run对象
//本节提到的所有样式都是基于XWPFRun的,
//你可以把XWPFRun理解成一小段文字的描述对象,
//这也是Word文档的特征,即文本描述性文档。
//来自Tony Qu http://tonyqus.sinaapp.com/archives/609
XWPFRun r1 = p1.CreateRun();
r1.SetBold(true);
r1.SetText("数据导出demo");
r1.SetBold(true);
r1.SetFontFamily("Arial");//设置雅黑字体
//创建表格对象列数写死了,可根据自己需要改进或者自己想想解决方案
XWPFTable table = doc.CreateTable(list.Count(), );
for (int i = ; i < list.Count(); i++)
{
table.GetRow(i).GetCell().SetText(list[i].Id.ToString());
table.GetRow(i).GetCell().SetText(list[i].Title);
table.GetRow(i).GetCell().SetText(list[i].Content);
table.GetRow(i).GetCell().SetText(list[i].AddTime);
}
//保存文件到磁盘
FileStream out1 = new FileStream("simpleTable.docx", FileMode.Create);
doc.Write(out1);
out1.Close();
}

二、设定单元格宽度

   table.GetRow().GetCell().GetCTTc().AddNewTcPr().tcW.w = "";//单元格宽
table.GetRow().GetCell().GetCTTc().AddNewTcPr().tcW.type = ST_TblWidth.dxa; CT_TcPr ctPr = cttc.AddNewTcPr(); //添加TcPr
ctPr.tcW = new CT_TblWidth();
ctPr.tcW.w = "";//单元格宽
ctPr.tcW.type = ST_TblWidth.dxa;

三、复制单元格样式,复制行样式,创建新行

注:表格的行没有设置样式的地方,样式设置具体到了单元格

特别说明: 在表格SetText() 的时候不能传入null 值,尤其是字符串需要处理成“”

XWPFTableRow row4 = table.GetRow();
row4.GetCell().SetText(stu.JapanHistory??"");
static void TestWord2()
{
//1.读取word 文档
string tempPath = @"D:\QLWork\QL.Ohter\LiuXue.Web.CRM\数据库\pinggu.docx";
string targetPath = "D:\\test_pg.docx"; using (FileStream fs = new FileStream(tempPath, FileMode.Open, FileAccess.Read, FileShare.ReadWrite))
{
XWPFDocument doc = new XWPFDocument(fs); //2.修改内容
//获取表格
CT_Tbl tbl = doc.Document.body.getTblArray().FirstOrDefault();
XWPFTable table = doc.GetTable(tbl);
//第一行
XWPFTableRow row0 = table.GetRow();
string str = row0.GetCell().GetText();
Console.WriteLine(str);
row0.GetCell().SetText("京国际文化学院");
row0.GetCell().SetText("2019年10月");
//第三行
XWPFTableRow row2 = table.GetRow();
row2.GetCell().SetText("张三丰 (拼音): zhagnsanfeng"); //创建一行
//CT_Row ctrow12 = new CT_Row();
//XWPFTableRow row12 = new XWPFTableRow(ctrow12, table);
//table.AddRow(row12, 12); //row12.CreateCell().SetText("小学");
//row12.CreateCell().SetText("聊城三中");
//row12.CreateCell().SetText("2019年10月~2019年3月");
//row12.CreateCell().SetText("5年制");
//row12.CreateCell().SetText("计算机应用"); //根据上一行创建一行,使用上一行的样式
XWPFTableRow row11 = table.GetRow();
XWPFTableCell oldCell = row11.GetCell(); CT_Row newctRow = new CT_Row();
XWPFTableRow rowNew = new XWPFTableRow(newctRow, table);
XWPFTableCell cell1 = rowNew.CreateCell(); cell1.SetText("小学");
CopyCellStyle(cell1, oldCell); cell1 = rowNew.CreateCell();
cell1.SetText("张营小学");
oldCell = row11.GetCell();
CopyCellStyle(cell1, oldCell); cell1 = rowNew.CreateCell();
cell1.SetText("2019年-5月~2019年10月");
oldCell = row11.GetCell();
CopyCellStyle(cell1, oldCell); cell1 = rowNew.CreateCell();
oldCell = row11.GetCell();
CopyCellStyle(cell1, oldCell); cell1 = rowNew.CreateCell();
oldCell = row11.GetCell();
CopyCellStyle(cell1, oldCell); table.AddRow(rowNew, ); //3.保存文件
using (FileStream fsw = new FileStream(targetPath, FileMode.OpenOrCreate, FileAccess.Write))
{
doc.Write(fsw);
doc.Close();
Console.WriteLine("word生成成功");
}
}
}
//复制单元格样式
static void CopyCellStyle(XWPFTableCell newCell, XWPFTableCell oldCell)
{
CT_Tc cttc1 = newCell.GetCTTc();
CT_TcPr tcpr1 = cttc1.AddNewTcPr(); tcpr1.tcW = oldCell.GetCTTc().tcPr.tcW;
tcpr1.tcBorders = oldCell.GetCTTc().tcPr.tcBorders;
tcpr1.tcMar = oldCell.GetCTTc().tcPr.tcMar;
tcpr1.gridSpan = oldCell.GetCTTc().tcPr.gridSpan;
}

更多:

.Net Core NOPI操作word(一)

.Net Excel操作之NPOI(二)常用操作封装

.Net Excel操作之NPOI(一)简介

.Net Core NOPI操作word(二) 表格操作的更多相关文章

  1. OpenXml操作Word的一些操作总结.

    OpenXml操作Word的一些操作总结. OpenXml相对于用MS提供的COM组件来生成WORD,有如下优势: 1.相对于MS 的COM组件,因为版本带来的不兼容问题,及各种会生成WORD半途会崩 ...

  2. asp.net操作word的表格

    近日开发中用户要求实现导出数据为Word,本来想使用html保存为word的实现,但因用户要求样式很高,使用html不好控制,并且导出中包括图片,使用页面导出时图片还是一个路径,不能把图片包括在wor ...

  3. Aspose.Word 操作word复杂表格 拆分单元格 复制行 插入行 文字颜色

    private void button3_Click(object sender, EventArgs e)         {             object savePathWord =&q ...

  4. OpenXml操作Word的一些操作总结.无word组件生成word.

    OpenXml相对于用MS提供的COM组件来生成WORD,有如下优势: 1.相对于MS 的COM组件,因为版本带来的不兼容问题,及各种会生成WORD半途会崩溃的问题. 2.对比填满一张30多页的WOR ...

  5. OpenXml操作Word的一些操作总结. - 天天不在

    OpenXml相对于用MS提供的COM组件来生成WORD,有如下优势: 1.相对于MS 的COM组件,因为版本带来的不兼容问题,及各种会生成WORD半途会崩溃的问题. 2.对比填满一张30多页的WOR ...

  6. OpenXml操作Word的一些操作总结.无word组件生成word.(转)

    http://www.cnblogs.com/zhouxin/p/3174936.html OpenXml相对于用MS提供的COM组件来生成WORD,有如下优势: 1.相对于MS 的COM组件,因为版 ...

  7. Selenium常用操作汇总二——如何操作select下拉框

    下面我们来看一下selenium webdriver是如何来处理select下拉框的,以http://passport.51.com/reg2.5p这个页面为例.这个页面中有4个下拉框,下面演示4种选 ...

  8. Selenium常用操作汇总二——如何操作cookies(转)

    Web 测试中我们经常会接触到Cookies,一个Cookies主要属性有”所在域.name.value.有效日期和路径",下面来讲一下怎么操作Cookies. import java.ut ...

  9. HDFS API 操作实例(二) 目录操作

    1. 递归读取文件名 1.1 递归实现读取文件名(scala + listFiles) /** * 实现:listFiles方法 * 迭代列出文件夹下的文件,只能列出文件 * 通过fs的listFil ...

  10. VBA操作word生成sql语句

    项目开始一般都是用word保存下数据库的文档 但是从表单一个一个的建表实在是很困难乏味,查查资料 1.可以生成一个html或者xml,检索结构生成sql.但是这个方式也蛮麻烦 2.查到vba可以操作w ...

随机推荐

  1. Synchronized与ReentrantLock区别总结

    这篇文章是关于这两个同步锁的简单总结比较,关于底层源码实现原理没有过多涉及,后面会有关于这两个同步锁的底层原理篇幅去介绍. 相似点: 这两种同步方式有很多相似之处,它们都是加锁方式同步,而且都是阻塞式 ...

  2. FFMPEG SDK 开发介绍(原创)

    来源:http://blog.sina.com.cn/s/blog_62a8419a01016exv.html 本文是作者在使用ffmpeg sdk开发过程中的实际经验,现在与大家分享,欢迎学习交流. ...

  3. Maven基础。

    ---恢复内容开始--- Maven: 1.概念. * maven 是一个项目管理工具. * maven的作用. 1.jar包.依赖管理.将jar包放在jar包仓库(pom.xml),不需要每个项目都 ...

  4. swipe滑动操作

    1.swipe() 滑动用法 swipe(self, start_x, start_y, end_x, end_y, duration=None) :Args: - start_x - 开始滑动的x坐 ...

  5. 【异常】Caused by: java.sql.SQLTransientConnectionException: HikariPool-1 - Connection is not available, request timed out after 30005ms.

    一.异常出现的场景 一次线上订单历史数据字段刷新操作,3张表100多万数据.由于同步更新太慢大概20分钟以上,所以采用异不的方式.代码如下: private void batchUpdate(List ...

  6. 【Linux】linux之如何清理磁盘空间

    相关命令: 1.查询磁盘空间占用情况df -h2.进入根目录,查询大文件与目录 cd /du -sh * | sort -n 查看上GB的目录并且排序,可以用这个命令du -h --max-depth ...

  7. Httpd服务入门知识-Httpd服务常见配置案例之DSO( Dynamic Shared Object)加载动态模块配置

    Httpd服务入门知识-Httpd服务常见配置案例之DSO( Dynamic Shared Object)加载动态模块配置 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.加载动 ...

  8. Office--CVE-2017-11882【远程代码执行】

    Office远程代码执行漏洞现POC样本 最近这段时间CVE-2017-11882挺火的.关于这个漏洞可以看看这里:https://www.77169.com/html/186186.html 今天在 ...

  9. mysql创建临时表,将查询结果插入已有的表

    A.临时表再断开于mysql的连接后系统会自动删除临时表中的数据,但是这只限于用下面语句建立的表:1)定义字段  CREATE TEMPORARY TABLE tmp_table (      nam ...

  10. 洛谷P2216 理想的正方形(单调队列)

    洛谷P2216 理想的正方形 题目链接 思路: 直接暴力显然不可行,可以发现每一个矩形向右边扩展时是一列一列增加,于是可以想到单调队列,用数组来维护当前每列的最大值.因为行也有限制,所以还要用一个单调 ...