NPOI创建DOCX常用操作

NPOI创建DOCX常用操作

1、  创建文档

XWPFDocument m_Docx = new XWPFDocument();

2、  页面设置

           //1‘=1440twip=25.4mm=72pt(磅point)=96px(像素pixel)

          //1px(像素pixel)=0.75pt(磅point)

// A4:W=11906 twip=8.269''=210mm,h=16838twip=11.693''=297mm

          //A5:W=8390 twip=5.827''=148mm,h=11906 twip=8.269''=210mm

          //A6:W=5953 twip=4.134''=105mm,h=8390twip=5.827''=1148mm

           //16k195mmX270mm:

           //16k184mmX260mm:

           //16k197mmX273mm:

           CT_SectPr m_SectPr = newCT_SectPr();

           //页面设置A4横向

          m_SectPr.pgSz.w = (ulong)16838;

          m_SectPr.pgSz.h = (ulong)11906;

          m_Docx.Document.body.sectPr = m_SectPr; 

3、  创建段落

1) XWPFParagraph gp = m_Docx.CreateParagraph();

2)      CT_Pm_p = m_Docx.Document.body.AddNewP();

           m_p.AddNewPPr().AddNewJc().val = ST_Jc.center;//段落水平居中

            XWPFParagraph gp = newXWPFParagraph(m_p, m_Docx); //创建XWPFParagraph

4、  段首行缩进

gp.IndentationFirstLine=(int)100;

可以用一个函数计算

    protected int Indentation(Stringfontname, int fontsize, int Indentationfonts, FontStylefs)

    {

            //字显示宽度,用于段首行缩进

         //字号与fontsize关系

        //初号(0号)=84,小初=721=522=44,小2=363=32,小3=304=28

//4=245=21,小5=186=15,小6=137=118=10

       Graphicsm_tmpGr = this.CreateGraphics();

        m_tmpGr.PageUnit = GraphicsUnit.Point;

         SizeF size = m_tmpGr.MeasureString("", new Font(fontname,fontsize * 0.75F, fs));

         return (int)size.Width* Indentationfonts * 10;

   }

   

gp.IndentationFirstLine= Indentation("宋体", 21, 2, FontStyle.Regular);//段首行缩进2字符

 

5、  行距设置

//单倍为默认值(240twip)不需设置,1.5倍=240X1.5=360twip,2倍=240X2=480twip

m_p.AddNewPPr().AddNewSpacing().line = "400";//行距固定20磅

     m_p.AddNewPPr().AddNewSpacing().lineRule= ST_LineSpacingRule.exact;

6、  创建RUN

        1)  XWPFRun gr= gp.CreateRun();

           gr.GetCTR().AddNewRPr().AddNewRFonts().ascii = "黑体";

           gr.GetCTR().AddNewRPr().AddNewRFonts().eastAsia = "黑体";

           gr.GetCTR().AddNewRPr().AddNewRFonts().hint = ST_Hint.eastAsia;

           gr.GetCTR().AddNewRPr().AddNewSz().val = (ulong)44;//2号字体

           gr.GetCTR().AddNewRPr().AddNewSzCs().val = (ulong)44;

           gr.GetCTR().AddNewRPr().AddNewB().val = true;//加粗

            gr.GetCTR().AddNewRPr().AddNewColor().val= "red";//字体颜色

           gr.SetText("DOCX");

        2) CT_R= m_p.AddNewR();

7、  创建表

1)  创建表

有两种方法:

a.方法1

XWPFTabletable = m_Docx.CreateTable(1, 1);//创建11列表

CT_Tblm_CTTbl = m_Docx.Document.body.GetTblArray()[0];//获得文档第一张表

b.方法2

 CT_Tblm_CTTbl = m_Docx.Document.body.AddNewTbl();

 XWPFTabletable = new XWPFTable(m_CTTbl,m_Docx);//创建11列表

2)  表水平居中

m_CTTbl.AddNewTblPr().jc = new CT_Jc();

m_CTTbl.AddNewTblPr().jc.val = ST_Jc.center;//表在页面水平居中

3)  表宽度

m_CTTbl.AddNewTblPr().AddNewTblW().w = "2000";//表宽度

m_CTTbl.AddNewTblPr().AddNewTblW().type = ST_TblWidth.dxa;

4)  表定位

//tblpXSpectblpX同时存在,则tblpXSpec优先tblpX

//tblpYSpectblpY同时存在,则tblpYSpec优先tblpY

m_CTTblPr.tblpPr = new CT_TblPPr();//表定位

m_CTTblPr.tblpPr.tblpX = "4003";//表左上角坐标

m_CTTblPr.tblpPr.tblpY = "365";

//m_CTTblPr.tblpPr.tblpXSpec = ST_XAlign.center;// tblpXSpec优先

  • 6
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 19
    评论
本DataGridView打印控件和.NET打印控件5.7版2014年11月2日修改完成,完全免费,在.NET2.0及以上环境下都可以使用(VB打印、C#打印都是可以的),有帮助文档与使用实例。 与上一版相比,控件5.7版的主要更改如下: 1、重写DataGridView导出Excel的代码,5.7版控件使用开源的NPOI库导出Excel,完全不依赖Office,不会再有因为没装Office或Office安装有问题而导出失败的情况,而且导出速度非常快,支持大于65536条记录的导出(自动分成多个工作表),效果非常好。导出Excel的接口未变,因此您不需要修改任何代码,只需替换控件即可; 2、SimpleReport打印组件添加了导出Excel功能,该功能在打印预览界面的按钮中; 3、多表头组件MulHeaderDataGridView添加了从Excel中导入数据(ImportFromExcel函数)及复制(Copy函数)与粘贴(Paste函数)的功能。其中导入Excel功能使用开源的NPOI组件实现,不依赖Office。 4、其他一些完善,比如解决了导出Excel时强制换行不自动显示,而是要双击才显示问题;导出Excel时,图片能按单元格大小导出。 本控件特色: 1、强大的DataGridView打印功能,不仅可以以多种形式(普通打印、分栏打印、跨页打印、工资条打印)打印DGV表格,基本上能完全按DGV控件本身设置的格式如字体、字号、背景颜色、前景颜色、单元格对齐方式等打印出来,文字图像都可以打印,而且是完全根据表格当前的显示顺序进行打印的,基本上做到了所见即所得的打印。 2、报表设计功能。报表模板设计组件EasyReport可以设计普通报表、分组报表、套打模板等,以DataGridView为数据源。控件的位置以毫米为计量单位,定位准确,很适合套打单据设计。 3、强大的图表打印功能。5.2版控件新增了一个Chartlet的组件,使用非常方便,可以生成柱形图、饼图、折线图等多种图形,而且可以设置2D或3D效果,既可以在打印控件中打印出来,也可以在Graphics对象中显示。 4、分组汇总打印DataGridVeiw功能,每组还可以自动换新页打印,还可以自动增加行号。 5、强大的文本打印输出功能,控件提供多个文本打印重载函数,打印文本时,如果需要,控件会自动换行和换页打印输出。还增加了以指定行间距及字符间距打印文本的功能,可以用固定行距,也可以用单或多行距打印文本。 6、强大的绘图功能,基本上.NET的GDI+的绘图函数(如直线、矩形、路径、多边形、曲线等)都有,只有个别函数的名称有点区别。 7、支持同一文档多种版面格式打印(类似于Word中的节的功能):对同一份文档,不同的页面可以设置不同的格式(纸张大小、纸张方向、页边距),只需要在新增一页时在NewPage方法中指定要使用的页面格式即可,使用非常简单。 8、报表文件保存功能。本控件允许将当前打印预览的内容保存为报表文件,以后使用本控件重新打开该报表文件即可重现原来保存报表时的打印内容。 9、Excel导出功能,可以将DataGridView导出为Excel文件,5.7版控件使用开源的NPOI导出Excel,速度非常快,效果非常好,5.4版还增加了合并单元格的导出功能。 10、打印DataGridView时的打印方案保存与读取功能。可以将当前打印参数保存为打印方案文件,或者从保存的打印方案文件中读取打印参数。 11、水印打印功能。根据需要,可以在页面中打印或不打印以半透明空心文字打印水印。 12、强大的容器控件打印功能(DrawPanel函数)。借助该函数,您只需要在您的容器控件中设计好要打印的内容及打印内容的相对位置,控件轻松帮你打印出来(如果超过一页,控件会自动换页续打)。 13、特殊文字效果打印功能。控件具有打印浮雕文字、阴影文字、空心文字、块文字的功能。 14、页眉页脚中既可打印文字,也可打印图像,或者即打印图像又打印输出文字。 15、图像与图标打印输出功能。 16、多表头(跨行跨列的复杂表头)打印功能,多表头组件支持多表头显示与打印、单元格内容的合并显示、打印与导出。 17、自定义纸张支持功能。 18、纸张背景图片设置打印功能。 19、.NET4.0支持功能(是单独的一个文件)。 20、直接打印窗口中的TreeView控件功能。 21、打印窗口中的ListView功能。 22、RichTextBox控件的RTF文本打印功能。 23、斜线表头打印功能(5.4版新增)。 24、二维码打印功能(5.5版本增加)。 25、5.6版新增的SimpleReport组件允许您在一个方案文件中管理多个打印方案,在打印预览时能自由在各个打印方案之间切换。 26、5.7版控件增加了使用开源的NPOI从Excel文件中导入数据到DataGridView的功能,以及DataGridView的复制与粘贴功能。 我将持续改进该控件,并将不断推出控件的新版本,要查看或下载控件的升级版本,请登陆网站:http://myyouping.download.csdn.net/ 。具体使用方法请参见帮助文件与实例文件,如有疑问或好的建议,请与我联系: 邮箱:[email protected] Q Q:479781502
要读取和修改.docx文件,可以使用Apache POI库。下面给出一个示例代码,以读取.docx文件中的文本并将其替换为新文本。 ```java import java.io.FileInputStream; import java.io.FileOutputStream; import org.apache.poi.xwpf.usermodel.XWPFDocument; import org.apache.poi.xwpf.usermodel.XWPFParagraph; import org.apache.poi.xwpf.usermodel.XWPFRun; public class DocxEditor { public static void main(String[] args) { try { FileInputStream fis = new FileInputStream("input.docx"); XWPFDocument document = new XWPFDocument(fis); // 遍历文档中的所有段落 for (XWPFParagraph para : document.getParagraphs()) { // 遍历段落中的所有文本运行 for (XWPFRun run : para.getRuns()) { String text = run.getText(0); if (text != null && text.contains("old text")) { text = text.replace("old text", "new text"); run.setText(text, 0); } } } FileOutputStream fos = new FileOutputStream("output.docx"); document.write(fos); fos.close(); fis.close(); document.close(); System.out.println("文档修改成功!"); } catch (Exception e) { e.printStackTrace(); } } } ``` 首先,从文件输入流中读取.docx文件并创建XWPFDocument对象。然后,遍历文档中的所有段落和文本运行,查找包含"old text"的文本并将其替换为"new text"。最后,将修改后的文档写入文件输出流中,并关闭所有流和文档对象。 注意:这只是一个基本示例,如果.docx文件中包含更复杂的内容(如表格、图片等),则需要使用更复杂的代码来读取和修改文档。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 19
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值