• Aspose.Word 的常见使用(2018-12-26 更新版)


    Aspose.Word 的常见使用

    起因

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

    思路

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

    入门,简单的示例

    Aspose.Words.Document doc = new Document();//新建一个空白的文档
    Aspose.Words.DocumentBuilder builder = new Aspose.Words.DocumentBuilder(doc);
    doc.Save("文件保存的全路径");
    
    这里面的`builder`相当于一个画笔,提前给他规定样式,然后他就能根据你的要求画出你想画的Word。这里的画笔使用的是就近原则,当上面没有定义了builder的时候,会使用默认的格式,当上面定义了某个格式的时候,使用最近的一个(即最后一个改变的样式)
    

    设定Word页面的样式

    builder.PageSetup.PaperSize = PaperSize.A4;//A4纸
    builder.PageSetup.Orientation = Aspose.Words.Orientation.Portrait;//方向
    builder.PageSetup.VerticalAlignment = Aspose.Words.PageVerticalAlignment.Top;//垂直对准
    builder.PageSetup.LeftMargin = 42;//页面左边距
    builder.PageSetup.RightMargin = 42;//页面右边距
    

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

    写入一段文字

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

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

    注意:`builder`在`Write`的时候,默认会使用上面规定的格式,除非你在使用`Write`前更新画笔的格式,所以,当你在做样式很多的Word的时候注意更改画笔的格式。
    

    添加图片

    builder.InsertImage("图片绝对地址");
    builder.InsertImage("图片绝对地址", 80, 80);//可以控制图片的宽高
    

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

    添加表格

    //开始添加表格
    Aspose.Words.Tables.Table table = builder.StartTable();
    //开始添加第一行,并设置表格行高
    RowFormat rowf = builder.RowFormat;
    rowf.Height = 40;
    // ....这里rowf可以有很多的设置
    //插入一个单元格
    builder.InsertCell();
    //设置单元格是否水平合并,None为不合并
    builder.CellFormat.HorizontalMerge = CellMerge.None;
    //设置单元格是否垂直合并,None为不合并
    builder.CellFormat.VerticalMerge = CellMerge.None;
    //设置单元格宽
    builder.CellFormat.Width = 40;
    //单元格垂直对齐方向
    builder.CellFormat.VerticalAlignment = CellVerticalAlignment.Center;
    //单元格水平对齐方向
    builder.ParagraphFormat.Alignment = ParagraphAlignment.Left;
    builder.CellFormat.FitText = true;//单元格内文字设为多行(默认为单行,会影响单元格宽)
    //单元格内添加文字
    builder.Write("这是第一行第一个单元格");
    builder.InsertCell();
    builder.CellFormat.Width = -1;//当不需要规定这个单元格的宽度的时候,设置成-1,会是自动宽度
    builder.Write("这是第一行第二个单元格");
    //结束第一行
    builder.EndRow();
    //结束表格
    builder.EndTable();
    //设置这个表格的上下左右,内部水平,垂直的线为白色(当背景为白色的时候就相当于隐藏边框了)
    table.SetBorder(BorderType.Left, LineStyle.Double, 1, Color.White, false);
    table.SetBorder(BorderType.Top, LineStyle.Double, 1, Color.White, false);
    table.SetBorder(BorderType.Right, LineStyle.Double, 1, Color.White, false);
    table.SetBorder(BorderType.Bottom, LineStyle.Double, 1, Color.White, false);
    table.SetBorder(BorderType.Vertical, LineStyle.Double, 1, Color.White, false);
    
    注意:最重要的是不用忘记开始表格,开始一行,结束一行,结束表格
    里面的设置可以根据个人需要修改,也可以不写使用默认的
    

    表格的合并单元格

    //横向合并单元格
    builder.CellFormat.HorizontalMerge = CellMerge.None;
    builder.CellFormat.HorizontalMerge = CellMerge.First;
    builder.CellFormat.HorizontalMerge = CellMerge.Previous;
    //纵向合并单元格
    builder.CellFormat.VerticalMerge = CellMerge.None;
    builder.CellFormat.VerticalMerge = CellMerge.First;
    builder.CellFormat.VerticalMerge = CellMerge.Previous;
    
    备注:当不需要合并单元格的时候设置为 None,当需要合并单元格的时候,第一个设置为First,并正常写入这个单元格应该存储的内容。后面的到了要和这个单元格合并的单元格的时候,不需要写入内容,只需要设置成Previous即可。
  • 相关阅读:
    【设计模式】适配器模式
    【设计模式】单例模式
    MSScriptControl详解(可实现在C#等语言中调用JAVASCRIPT代码)
    一:简介
    你是否经常想写点什么?
    SQL server2008无法收缩日志
    SqlServer中把结果集放到到临时表的方法(转)
    (转)64位系统安装Delphi7提示Can’t load package:dclite70.bpl 以及 提示地址错误
    太有用了,所以转:Delphi下16进制位图数据转位图
    C# 使用access,报错:标准表达式中数据类型不匹配
  • 原文地址:https://www.cnblogs.com/itljf/p/10179028.html
Copyright © 2020-2023  润新知