C# 对Excel文档打印时的页面设置

简介:

 

1、对打印页面的朝向,页宽,页高进行设置

参考源码[1]

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
using  Excel = Microsoft.Office.Interop.Excel;
Excel.Application tmpExcel =  new  Excel.ApplicationClass();
Excel.Workbook tmpbook = tmpExcel.Workbooks.Open(tmppath, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);   //表格的权限设定,如只读,密码,权限
<br data-filtered= "filtered" > //以下是添加新的sheet
Excel.Worksheet objsheet = (Excel.Worksheet)tmpbook.Worksheets.Add(Type.Missing, Type.Missing, Type.Missing);
objsheet.PageSetup.Orientation = XlPageOrientation.xlLandscape; //页面方向横向
 
objsheet.PageSetup.Zoom =  false //打印时页面设置,必须设置为false,下面的二行页高,页宽才有效
objsheet.PageSetup.FitToPagesTall = 1;  //页高
objsheet.PageSetup.FitToPagesWide = 1;  //页宽
  
objsheet.PageSetup.Zoom = 75; //打印时页面设置,缩放比例
objsheet.PageSetup.TopMargin = 0;  //上边距为0
objsheet.PageSetup.BottomMargin = 0;  //下边距为0
objsheet.PageSetup.LeftMargin = 0;  //左边距为0
objsheet.PageSetup.RightMargin = 0;  //右边距为0
objsheet.PageSetup.CenterHorizontally =  true ; //水平居中

 

示例代码2:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
exce.Application.Workbooks.Add( true );
Workbookbooks=(Excel.Workbook)exce.Workbooks[1];
Excel.Worksheetsheets=(Excel.Worksheet)books.Worksheets[1];
exce.Cells.VerticalAlignment=2; //单元格文字垂直居中
sheets.Cells.Font.Name= "宋体" ;
sheets.Cells.Font.Size=11;
<br> //设置表格标题
sheets.Cells[1,1]= "正在生成表格,请稍候.....警告:在生成期间,请不要编辑单元格" ;
exce.get_Range( "A1" , "P1" ).MergeCells= true ; //合并单元格
exce.get_Range( "a1" , "a1" ).HorizontalAlignment=3; //水平居中
exce.get_Range( "a1" , "a1" ).Font.Name= "黑体" ;
exce.get_Range( "a1" , "a1" ).Font.Size=20;
exce.get_Range( "a1" , "a1" ).Font.Bold= true ;
exce.get_Range( "A2" , "P2" ).MergeCells= true ;
sheets.Cells[2,1]= "部门:" +treeView1.SelectedNode.FullPath+
"(共计:" +RowCount.ToString()+ "项)" ;
 
//设置表格值
 
.......
 
 
exce.get_Range( "a3" , "p3" ).HorizontalAlignment=3; //列名称居中
sheets.Columns.AutoFit(); //设置最合适列宽
 
......
 
exce.get_Range( "A3" ,ENDSELECT).Borders.LineStyle=1; //设置选中单元格的网格线
sheets.Cells.Select();
sheets.Columns.AutoFit(); //再次设置最合适列宽
 
sheets.Cells[1,1]= "总帐" ;
sheets.Cells[2,1]= "部门:" +treeView1.SelectedNode.FullPath+
"(共计:" +RowCount.ToString()+ "项,合计数量:" +
Numer.ToString()+ "合计金额:" +jine.ToString( "C2" )+ "元)" ;
ENDSELECT= "A" +(RowCount+3);
exce.get_Range( "A3" ,ENDSELECT).HorizontalAlignment=3; //设置序号列居中
ENDSELECT= "G" +(RowCount+3);
exce.get_Range( "G4" ,ENDSELECT).NumberFormatLocal= "#,##0.00_" ; //设置金额列为货币式
exce.get_Range( "B4" , "B4" ).Select();
exce.ActiveWindow.FreezePanes= true ; //冻结窗口
<br> //页面设置
exce.ActiveWindow.DisplayGridlines= false ; //不显示网格线
sheets.DisplayAutomaticPageBreaks= true ; //显示分页线
sheets.PageSetup.CenterFooter= "第&P页,共&N页" ;
sheets.PageSetup.TopMargin=exce.InchesToPoints(0.590551181102362); //上1.5
sheets.PageSetup.BottomMargin=exce.InchesToPoints(0.590551181102362); //下1.5
sheets.PageSetup.LeftMargin=exce.InchesToPoints(0.78740157480315); //左边距2
sheets.PageSetup.RightMargin=exce.InchesToPoints(0.393700787401575); //右边距1
sheets.PageSetup.HeaderMargin=exce.InchesToPoints(0.393700787401575); //页眉1
sheets.PageSetup.FooterMargin=exce.InchesToPoints(0.393700787401575); //页脚1
sheets.PageSetup.CenterHorizontally= true ; //水平居中
sheets.PageSetup.PrintTitleRows= "$1:$3" ; //顶端标题行
sheets.PageSetup.PaperSize=Excel.XlPaperSize.xlPaperA3; //.xlPaperB4;//纸张大小
sheets.PageSetup.Orientation=Excel.XlPageOrientation.xlLandscape; //纸张方向.横向

 

 

2、打印选项及打印文档[2]

打印Excel文档是一个很常见的操作,但有时候我们会碰到各种不同的打印需求, 例如只打印一个Excel工作表的其中一部分,或打印时每页都有表头,或把工作表中超出1页所有内容打印到1页上等等,这时我们需要对Excel的打印选 项进行设置。这篇文章主要是分享如何使用Excel组件及C#来设置一些常见的Excel打印选项及打印Excel文档。

下面这个Excel工作表共含有17行,20列数据:

                       

目标:将第7, 8行的所有数据打印到一页上,并打印表头(标题行)。

创建一个WinForm项目,使用如下命名空间:

using System;
using System.Drawing.Printing;
using System.Windows.Forms; using Spire.Xls;

 

步骤1创建一个新的workbook对象并加载Excel文档。

Workbook workbook = new Workbook();
workbook.LoadFromFile("Sample.xlsx");

 

步骤2获取该Excel文档的第一个工作表,并设置打印选项。

Worksheet sheet = workbook.Worksheets[0];

 

下面列出几个常设置的打印选项:

设置打印区域/范围:

sheet.PageSetup.PrintArea = "A7:T8";

 

设置打印表头(标题行):

sheet.PageSetup.PrintTitleRows = "$1:$1";

 

设置excel工作表缩放为一页宽一页高:

sheet.PageSetup.FitToPagesWide = 1;
sheet.PageSetup.FitToPagesTall = 1;

这里可以设置它们的值为0或1来改变打印效果以满足不同需求。 

 

除此之外还可以设置页面方向及打印页面大小等:

设置页面方向:

sheet.PageSetup.Orientation = PageOrientationType.Portrait;

 

设置打印页面大小:

sheet.PageSetup.PaperSize = PaperSizeType.PaperA3;

 

步骤3创建一个新的PrintDialog对象,设置dialog属性及打印页面范围并打印文档。

复制代码
复制代码
PrintDialog dialog = new PrintDialog();
dialog.AllowPrintToFile = true;
dialog.AllowCurrentPage = true; dialog.AllowSomePages = true; dialog.AllowSelection = true; dialog.UseEXDialog = true; dialog.PrinterSettings.Duplex = Duplex.Simplex; dialog.PrinterSettings.FromPage = 0; dialog.PrinterSettings.ToPage = 8; dialog.PrinterSettings.PrintRange = PrintRange.SomePages; workbook.PrintDialog = dialog; PrintDocument pd = workbook.PrintDocument; if (dialog.ShowDialog() == DialogResult.OK) { pd.Print(); }
复制代码
复制代码

 

运行程序会出现如下对话框:

 

这里我选择Microsoft XPS Document Writer将这个excel文档打印为XPS格式,得到的XPS文件如下:

 全部代码:

复制代码
using System;
using System.Drawing.Printing;
using System.Windows.Forms;
using Spire.Xls;
 
namespace Print_Excel_in_csharp
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            Workbook workbook = new Workbook();
            workbook.LoadFromFile("Sample.xlsx");           

            Worksheet sheet = workbook.Worksheets[0];
            sheet.PageSetup.PrintArea = "A7:T8";
            sheet.PageSetup.PrintTitleRows = "$1:$1";
            sheet.PageSetup.FitToPagesWide = 1;
            sheet.PageSetup.FitToPagesTall = 1;
            //sheet.PageSetup.Orientation = PageOrientationType.Landscape;
            //sheet.PageSetup.PaperSize = PaperSizeType.PaperA3;
           
            PrintDialog dialog = new PrintDialog();
            dialog.AllowPrintToFile = true;
            dialog.AllowCurrentPage = true;
            dialog.AllowSomePages = true;
            dialog.AllowSelection = true;
            dialog.UseEXDialog = true;
            dialog.PrinterSettings.Duplex = Duplex.Simplex;
            dialog.PrinterSettings.FromPage = 0;
            dialog.PrinterSettings.ToPage = 8;
            dialog.PrinterSettings.PrintRange = PrintRange.SomePages;
            workbook.PrintDialog = dialog;
            PrintDocument pd = workbook.PrintDocument;
            if (dialog.ShowDialog() == DialogResult.OK)
            { pd.Print(); }
        }

    }

}
复制代码

 

 

 

 

参考博文

1. brian0031C#打印页面设置(横向,页宽,页高), 2012-03.

2. E-iceblueC# 设置Excel打印选项及打印excel文档2016-05.

3. c#的excel边距设置 , 2008-6.

 

扩展阅读

1. C# 合并及拆分PDF文件

2. C# 给Word文档添加内容控件

3. C#读写xml文件

 

没有整理与归纳的知识,一文不值!高度概括与梳理的知识,才是自己真正的知识与技能。 永远不要让自己的自由、好奇、充满创造力的想法被现实的框架所束缚,让创造力自由成长吧! 多花时间,关心他(她)人,正如别人所关心你的。理想的腾飞与实现,没有别人的支持与帮助,是万万不能的。





  本文转自wenglabs博客园博客,原文链接:http://www.cnblogs.com/arxive/p/5794699.html,如需转载请自行联系原作者

相关文章
|
2月前
|
数据安全/隐私保护
Excel中如何设置随机密码
Excel中如何设置随机密码
|
10月前
|
Java API Apache
Java编程如何读取Word文档里的Excel表格,并在保存文本内容时保留表格的样式?
【10月更文挑战第29天】Java编程如何读取Word文档里的Excel表格,并在保存文本内容时保留表格的样式?
663 5
|
11月前
如何设置Excel的快捷键?
【10月更文挑战第19天】如何设置Excel的快捷键?
1359 8
|
9月前
|
Python
使用OpenPyXL库实现Excel单元格其他对齐方式设置
本文介绍了如何使用Python的`openpyxl`库设置Excel单元格中的文本对齐方式,包括文本旋转、换行、自动调整大小和缩进等,通过具体示例代码展示了每种对齐方式的应用方法,适合需要频繁操作Excel文件的用户学习参考。
419 85
使用OpenPyXL库实现Excel单元格其他对齐方式设置
|
11月前
|
数据处理 Python
Python实用记录(十):获取excel数据并通过列表的形式保存为txt文档、xlsx文档、csv文档
这篇文章介绍了如何使用Python读取Excel文件中的数据,处理后将其保存为txt、xlsx和csv格式的文件。
517 3
Python实用记录(十):获取excel数据并通过列表的形式保存为txt文档、xlsx文档、csv文档
|
10月前
|
XML C# 开发工具
C# 删除Word文档中的段落
【11月更文挑战第3天】本文介绍了两种方法来操作 Word 文档:一是使用 `Microsoft.Office.Interop.Word` 库,适用于 Windows 环境下操作 Word 文档,需引用相应库并在代码中引入命名空间;二是使用 Open XML SDK,适用于处理 .docx 格式的文档,通过引用 `DocumentFormat.OpenXml` 库实现。文中提供了示例代码,展示了如何打开、删除段落并保存文档。
230 5
|
12月前
|
SQL C# 数据库
EPPlus库的安装和使用 C# 中 Excel的导入和导出
本文介绍了如何使用EPPlus库在C#中实现Excel的导入和导出功能。首先,通过NuGet包管理器安装EPPlus库,然后提供了将DataGridView数据导出到Excel的步骤和代码示例,包括将DataGridView转换为DataTable和使用EPPlus将DataTable导出为Excel文件。接着,介绍了如何将Excel数据导入到数据库中,包括读取Excel文件、解析数据、执行SQL插入操作。
EPPlus库的安装和使用 C# 中 Excel的导入和导出
内存或磁盘不足,excel无法再次打开或保存任何文档
内存或磁盘不足,excel无法再次打开或保存任何文档
296 2
|
文字识别 C# Python
使用C#将几个Excel文件合并去重分类
使用C#将几个Excel文件合并去重分类
144 3
|
关系型数据库 数据库 PostgreSQL
在C#中获取与设置Windows的字符编码方式
通过以上步骤,你可以在Docker环境下有效地重启PostgreSQL服务。这对于维护数据库健康、应用更新或环境配置更改后确保数据库服务正常运行至关重要。根据你的具体需求和环境设置,选择合适的方法来执行重启操作。
87 0

热门文章

最新文章