因项目需要,而且使用html转Word的时候,样式不兼容问题,于是只能使用Aspose.Word通过代码生成。下面是通过DocumentBuilder来设计Word的,但是和使用模型拼接的差不多,原理基本一致。

这里是说使用Aspose.Word的使用思路,只想某个功能是怎么使用的可以跳过
代码都是人写的,所以每一个代码都有他的风格,了解这些代码作者的思路有利于我们去使用它。
简单使用Word,无非就是文字,图片,表格以及页面的样式。如果了解Css和英语好点的基本都是可以在VS里面点出来的,最难的就是最开始的入门的。

  1. Aspose.Words.Document doc = new Document();//新建一个空白的文档
  2. Aspose.Words.DocumentBuilder builder = new Aspose.Words.DocumentBuilder(doc);
  3. doc.Save("文件保存的全路径");
  1. 这里面的`builder`相当于一个画笔,提前给他规定样式,然后他就能根据你的要求画出你想画的Word。这里的画笔使用的是就近原则,当上面没有定义了builder的时候,会使用默认的格式,当上面定义了某个格式的时候,使用最近的一个(即最后一个改变的样式)
  1. builder.PageSetup.PaperSize = PaperSize.A4;//A4纸
  2. builder.PageSetup.Orientation = Aspose.Words.Orientation.Portrait;//方向
  3. builder.PageSetup.VerticalAlignment = Aspose.Words.PageVerticalAlignment.Top;//垂直对准
  4. builder.PageSetup.LeftMargin = 42;//页面左边距
  5. builder.PageSetup.RightMargin = 42;//页面右边距

关于页面的设置,基本都在PageSetup中,根据需要和正常的名字,基本都可以猜出来

  1. //获取ParagraphFormat对象,关于行的样式基本都在这里
  2. var ph = builder.ParagraphFormat;
  3. //文字对齐方式
  4. ph.Alignment = ParagraphAlignment.Center;
  5. // 单倍行距 = 12 , 1.5 倍 = 18
  6. ph.LineSpacing = 12;
  7. //获取Font对象,关于文字的大小,颜色,字体等等基本都在这个里面
  8. Aspose.Words.Font font = builder.Font;
  9. //字体大小
  10. font.Size = 22;
  11. //是否粗体
  12. font.Bold = false;
  13. //下划线样式,None为无下划线
  14. font.Underline = Underline.None;
  15. //字体颜色
  16. font.Color = Color.Black;//C#的颜色
  17. font.Color = System.Drawing.ColorTranslator.FromHtml("#3b3131");//自定义颜色
  18. //设置字体
  19. font.NameFarEast = "宋体";
  20. //添加文字
  21. builder.Write("添加的文字");
  22. //添加回车
  23. builder.Writeln();
  24. //添加文字后回车
  25. builder.Writeln("添加的文字后回车");

基本使用到的就是这几个了,如果需要更多可以自己在VS里面点后试试看。

  1. 注意:`builder``Write`的时候,默认会使用上面规定的格式,除非你在使用`Write`前更新画笔的格式,所以,当你在做样式很多的Word的时候注意更改画笔的格式。
  1. builder.InsertImage("图片绝对地址");
  2. builder.InsertImage("图片绝对地址", 80, 80);//可以控制图片的宽高

基本是这样使用,当然还有是其他很多种的参数,比如ImageStream等,在使用的时候可以根据需要使用

  1. //开始添加表格
  2. Aspose.Words.Tables.Table table = builder.StartTable();
  3. //开始添加第一行,并设置表格行高
  4. RowFormat rowf = builder.RowFormat;
  5. rowf.Height = 40;
  6. // ....这里rowf可以有很多的设置
  7. //插入一个单元格
  8. builder.InsertCell();
  9. //设置单元格是否水平合并,None为不合并
  10. builder.CellFormat.HorizontalMerge = CellMerge.None;
  11. //设置单元格是否垂直合并,None为不合并
  12. builder.CellFormat.VerticalMerge = CellMerge.None;
  13. //设置单元格宽
  14. builder.CellFormat.Width = 40;
  15. //单元格垂直对齐方向
  16. builder.CellFormat.VerticalAlignment = CellVerticalAlignment.Center;
  17. //单元格水平对齐方向
  18. builder.ParagraphFormat.Alignment = ParagraphAlignment.Left;
  19. builder.CellFormat.FitText = true;//单元格内文字设为多行(默认为单行,会影响单元格宽)
  20. //单元格内添加文字
  21. builder.Write("这是第一行第一个单元格");
  22. builder.InsertCell();
  23. builder.CellFormat.Width = -1;//当不需要规定这个单元格的宽度的时候,设置成-1,会是自动宽度
  24. builder.Write("这是第一行第二个单元格");
  25. //结束第一行
  26. builder.EndRow();
  27. //结束表格
  28. builder.EndTable();
  29. //设置这个表格的上下左右,内部水平,垂直的线为白色(当背景为白色的时候就相当于隐藏边框了)
  30. table.SetBorder(BorderType.Left, LineStyle.Double, 1, Color.White, false);
  31. table.SetBorder(BorderType.Top, LineStyle.Double, 1, Color.White, false);
  32. table.SetBorder(BorderType.Right, LineStyle.Double, 1, Color.White, false);
  33. table.SetBorder(BorderType.Bottom, LineStyle.Double, 1, Color.White, false);
  34. table.SetBorder(BorderType.Vertical, LineStyle.Double, 1, Color.White, false);
  1. 注意:最重要的是不用忘记开始表格,开始一行,结束一行,结束表格
  2. 里面的设置可以根据个人需要修改,也可以不写使用默认的
  1. //横向合并单元格
  2. builder.CellFormat.HorizontalMerge = CellMerge.None;
  3. builder.CellFormat.HorizontalMerge = CellMerge.First;
  4. builder.CellFormat.HorizontalMerge = CellMerge.Previous;
  5. //纵向合并单元格
  6. builder.CellFormat.VerticalMerge = CellMerge.None;
  7. builder.CellFormat.VerticalMerge = CellMerge.First;
  8. builder.CellFormat.VerticalMerge = CellMerge.Previous;
  1. 备注:当不需要合并单元格的时候设置为 None,当需要合并单元格的时候,第一个设置为First,并正常写入这个单元格应该存储的内容。后面的到了要和这个单元格合并的单元格的时候,不需要写入内容,只需要设置成Previous即可。

版权声明:本文为itljf原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/itljf/p/10179028.html