C#操作excel打印
- using System;
- using System.Data;
- using System.IO;
- using System.Runtime.InteropServices;
- using System.Threading;
- using System.Windows.Forms;
- using Microsoft.Office.Core;
- using Excel = Microsoft.Office.Interop.Excel;
- namespace WindowsFormsApplication1
- {
- public partial class Form1 : Form
- {
- private bool isStartPrint = false;
- public Form1()
- {
- InitializeComponent();
- }
- private void button1_Click(object sender, EventArgs e)
- {
- //string OriginalPath = Path.GetDirectoryName(Application.ExecutablePath) + "\\IMS.accdb";
- ////初始化数据库
- //DataBase.OleDbObject.InitDatabase(OriginalPath);
- //DataBase.OleDbObject.OpenDb();
- //int k=DataBase.OleDbObject.Select("select * from ElementInventory").Rows.Count;
- //初始化要写入Excel的数据
- DataTable dt = new DataTable();
- for (int i = ; i < ; i++)
- {
- DataColumn dc = new DataColumn();
- dc.ColumnName = "name" + i;
- dc.DataType = typeof(string);
- dt.Columns.Add(dc);
- }
- for (int i = ; i < ; i++)
- {
- DataRow dr = dt.NewRow();
- if (i % == )
- {
- dr[] = "测试用例" + i + "号,开始测试是否自动换行,以及页面高度自适应。";
- }
- else
- {
- dr[] = "测试用例" + i + "号";
- }
- for (int j = ; j < ; j++)
- {
- dr[j] = j;
- }
- dt.Rows.Add(dr);
- }
- if (!isStartPrint)
- {
- Thread th = new Thread(delegate ()
- {
- DataTabletoExcel(dt, "测试.xlsx");
- });
- th.Start();
- isStartPrint = true;
- }
- else
- {
- MessageBox.Show("打印程序已启用,请稍后……", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
- }
- //DataTabletoExcel(dt, "测试.xlsx");
- }
- public void DataTabletoExcel(System.Data.DataTable dtTemp, string strFileName)
- {
- int rowNum = dtTemp.Rows.Count; //先得到dtTemp的行数
- int columnNum = dtTemp.Columns.Count; //列数
- Excel.Application ExcelApp = new Excel.Application(); //声明一个应用程序类实例
- //ExcelApp.DefaultFilePath = ""; //默认文件路径导出excel的路径还是在参数strFileName里设置
- //ExcelApp.DisplayAlerts = true;
- //ExcelApp.SheetsInNewWorkbook = 1;///返回或设置 Microsoft Excel 自动插入到新工作簿中的工作表数目。
- Excel.Workbook worksBook = ExcelApp.Workbooks.Add(); //创建一个新工作簿
- Excel.Worksheet workSheet = (Excel.Worksheet)worksBook.Worksheets[]; //在工作簿中得到sheet。
- if (workSheet == null)
- {
- System.Diagnostics.Debug.WriteLine("ERROR: worksheet == null");
- return;
- }
- workSheet.Name = "测试Sheet1"; //工作表的名称
- workSheet.Cells.WrapText = true; //设置所有列的文本自动换行
- workSheet.Cells.EntireRow.AutoFit(); //设置所有列自动调整行高
- #region 绘制列
- ///自定义方法,向sheet中绘制列
- RangeMark(workSheet, "A1", "A2", "合并竖列1");
- RangeMark(workSheet, "B1", "B2", "合并竖列2");
- RangeMark(workSheet, "C1", "C2", "合并竖列3");
- RangeMark(workSheet, "D1", "D2", "合并竖列4");
- RangeMark(workSheet, "E1", "E2", "合并竖列5");
- RangeMark(workSheet, "F1", "H1", "合并横行1");
- RangeMark(workSheet, "F2", "F2", "合并横行1.1");
- RangeMark(workSheet, "G2", "G2", "合并横行1.2");
- RangeMark(workSheet, "H2", "H2", "合并横行1.3");
- RangeMark(workSheet, "I1", "K1", "合并横行2");
- RangeMark(workSheet, "I2", "J2", "合并横行2.1");
- RangeMark(workSheet, "K2", "K2", "合并横行2.2");
- #endregion
- //将DataTable中的数据导入Excel中
- for (int i = ; i < rowNum; i++)
- {
- for (int j = ; j < columnNum; j++)
- {
- workSheet.Cells[i + , j + ] = dtTemp.Rows[i][j].ToString(); //文本
- }
- }
- ///保存路径
- string filePath = @"C:\Users\Admin\Desktop\" + strFileName;
- if (File.Exists(filePath))
- {
- try
- {
- File.Delete(filePath);
- }
- catch (Exception)
- {
- }
- }
- ExcelApp.Visible = true;
- //------------------------打印页面相关设置--------------------------------
- workSheet.PageSetup.PaperSize = Excel.XlPaperSize.xlPaperA4;//纸张大小
- workSheet.PageSetup.Orientation = Excel.XlPageOrientation.xlLandscape;//页面横向
- //workSheet.PageSetup.Zoom = 75; //打印时页面设置,缩放比例百分之几
- workSheet.PageSetup.Zoom = false; //打印时页面设置,必须设置为false,页高,页宽才有效
- workSheet.PageSetup.FitToPagesWide = ; //设置页面缩放的页宽为1页宽
- workSheet.PageSetup.FitToPagesTall = false; //设置页面缩放的页高自动
- workSheet.PageSetup.LeftHeader = "Nigel";//页面左上边的标志
- workSheet.PageSetup.CenterFooter = "第 &P 页,共 &N 页";//页面下标
- workSheet.PageSetup.PrintGridlines = true; //打印单元格网线
- workSheet.PageSetup.TopMargin = 1.5 / 0.035; //上边距为2cm(转换为in)
- workSheet.PageSetup.BottomMargin = 1.5 / 0.035; //下边距为1.5cm
- workSheet.PageSetup.LeftMargin = / 0.035; //左边距为2cm
- workSheet.PageSetup.RightMargin = / 0.035; //右边距为2cm
- workSheet.PageSetup.CenterHorizontally = true; //文字水平居中
- //------------------------打印页面设置结束--------------------------------
- ///http://blog.csdn.net/wanmingtom/article/details/6125599
- worksBook.PrintPreview(); //打印预览
- //worksBook.PrintOutEx(); //直接打印
- //worksBook.Close(); //关闭工作空间
- //ExcelApp.Quit(); //退出程序
- //workSheet.SaveAs(filePath); //另存表
- KillProcess(ExcelApp); //杀掉生成的进程
- isStartPrint = false; //打印完毕
- GC.Collect(); //垃圾回收机制
- }
- /// <summary>
- /// 引用Windows句柄,获取程序PID
- /// </summary>
- /// <param name="Hwnd"></param>
- /// <param name="PID"></param>
- /// <returns></returns>
- [DllImport("User32.dll")]
- public static extern int GetWindowThreadProcessId(IntPtr Hwnd, out int PID);
- /// <summary>
- /// 杀掉生成的进程
- /// </summary>
- /// <param name="AppObject">进程程对象</param>
- private static void KillProcess(Excel.Application AppObject)
- {
- int Pid = ;
- IntPtr Hwnd = new IntPtr(AppObject.Hwnd);
- System.Diagnostics.Process p = null;
- try
- {
- GetWindowThreadProcessId(Hwnd, out Pid);
- p = System.Diagnostics.Process.GetProcessById(Pid);
- if (p != null)
- {
- p.Kill();
- p.Dispose();
- }
- }
- catch (Exception ex)
- {
- System.Diagnostics.Debug.WriteLine("进程关闭失败!异常信息:" + ex);
- }
- }
- /// <summary>
- /// 创建表头单元格,包括合并单元格
- /// </summary>
- /// <param name="workSheet">工作表</param>
- /// <param name="startCell">单元格起始格编号</param>
- /// <param name="endCell">单元格结束编号</param>
- /// <param name="strText">单元格名称</param>
- private static bool RangeMark(Excel.Worksheet workSheet, string startCell, string endCell, string strText)
- {
- //创建一个区域对象。第一个参数是开始格子号,第二个参数是终止格子号。比如选中A1——D3这个区域。
- Excel.Range range = (Excel.Range)workSheet.get_Range(startCell, endCell);
- if (range == null)
- {
- System.Diagnostics.Debug.WriteLine("ERROR: range == null");
- return false;
- }
- range.Merge(); //合并方法,0的时候直接合并为一个单元格
- range.Font.Size = ; //字体大小
- range.Font.Name = "黑体"; //字体
- range.WrapText = true; //文本自动换行
- range.EntireRow.AutoFit(); //自动调整行高
- //range.RowHeight = 20;
- //range.EntireColumn.AutoFit(); //自动调整列宽
- range.ColumnWidth = ;
- range.HorizontalAlignment = XlVAlign.xlVAlignCenter; //横向居中
- range.Value = strText; //合并单元格之后,设置其中的文本
- range.Interior.ColorIndex = ; //填充颜色
- range.Cells.Borders.LineStyle = ; //设置单元格边框的粗细
- return true;
- }
- }
- }
C#操作excel打印的更多相关文章
- unity3d 下操作excel 与打印
原地址:http://www.colabug.com/thread-1146390-1-1.html 因项目需要,需在unity下实现写入excel.打印功能.因之前在winform里操作过excel ...
- 一个由正则表达式引发的血案 vs2017使用rdlc实现批量打印 vs2017使用rdlc [asp.net core 源码分析] 01 - Session SignalR sql for xml path用法 MemCahe C# 操作Excel图形——绘制、读取、隐藏、删除图形 IOC,DIP,DI,IoC容器
1. 血案由来 近期我在为Lazada卖家中心做一个自助注册的项目,其中的shop name校验规则较为复杂,要求:1. 英文字母大小写2. 数字3. 越南文4. 一些特殊字符,如“&”,“- ...
- VB操作EXCEL文件
用VB操作Excel(VB6.0)(整理) 首先创建Excel对象,使用ComObj:Dim ExcelID as Excel.ApplicationSet ExcelID as new Excel. ...
- Delphi操作Excel大全
Delphi操作Excel大全 DELPHI操作excel(转)(一) 使用动态创建的方法 首先创建 Excel 对象,使用ComObj:var ExcelApp: Variant;ExcelApp ...
- VBS操作Excel常见方法
VBS操作Excel常见方法 作者: 字体:[增加 减小] 类型:转载 时间:2009-11-13我要评论 VBS控制Excel常见方法,需要的朋友可以参考下. dim oExcel,oWb,oShe ...
- Ruby操作Excel的方法与技巧大全
测试工作中,批量的数据通常会放到excel表格中,测试输出的数据写回表格中,这样输入输出易于管理,同时清晰明了 使用ruby来操作excel文件首先需要在脚本里包含以下语句 require'win32 ...
- C++ builder 操作Excel方法(据网上资料整理)
c++ builder 操作Excel方法,下面是从网上找到的一些不错的方法,学习一下: 用OLE操作Excel(目前最全的资料)(04.2.19更新) 本文档部分资料来自互联网,大部分是ccrun( ...
- C#对Excel打印时,PageSetup 对象详解
PageSetup 对象包含所有页面设置的属性(左边距.底部边距.纸张大小等).下面按“页面”.“页边距”.“页眉/页脚”.“工作表”和“无对应选项卡”五个类别,逐一介绍. 一.页面 与“页面”选项卡 ...
- C# 操作 Excel 常见问题收集和整理(定期更新,欢迎交流)
经常会有项目需要把表格导出为 Excel 文件,或者是导入一份 Excel 来操作,那么如何在 C# 中操作 Excel 文件成了一个最基本的问题. 做开发这几年来,陆陆续续也接触过这样的需求,但因为 ...
随机推荐
- MySQL-事务的实现-redo
MySQL中事务: 事务的实现: ACID: 原子性(A : Atomicity) 一致性(C : consistency ) 隔离性(I : isolation) 持久性(D : dura ...
- 摆花 (DP动态规划)
2012_p3 摆花 (flower.cpp/c/pas) 时间限制: 1 Sec 内存限制: 128 MB提交: 17 解决: 10[提交][状态][讨论版][命题人:外部导入] 题目描述 3. ...
- AngularJS:template2
ylbtech-AngularJS: 1.返回顶部 1. 2. 2.返回顶部 3.返回顶部 4.返回顶部 5.返回顶部 1. 2. 6.返回顶部 作者:ylbtech出处:h ...
- PHP实现四种基本排序算法 得多消化消化
1.冒泡排序 // 冒泡排序 思路分析:在要排序的一组数中,对当前还未排好的序列,从前往后对相邻的两个数依次进行比较和调整,让较大的数往下沉,较小的往上冒.即,每当两相邻的数比较后发现它们的排序与排序 ...
- mybatis 学习一 建立maven项目
一.直接建立Maven项目方法 1.建立Maven项目 接下来使用Eclipse的maven构建一个web项目,以构建SpringMVC项目为例: 1.1 选择建立Maven Project 选择Fi ...
- C#字符串Split方法的误区
string s = "aaa1bbb2ccc1ddd"; string[] ss = s.Split("12".ToCharArray()); ...
- babel-polyfill使用简介
babel-polyfill介绍 简介 使用这个插件你可随心所欲的使用es6甚至更高版本的方法,这个插件自动转码 安装 这个插件必须在你的源码运行之前运行,所以必须安装成dependency npm ...
- oracle数据库中函数的递归调用
如有下面的表结构AAAA,用一个字段prev_id表示记录的先后顺序,要对其排序,需要用的递归函数 ID PREV_ID CONT 99 a 23 54 d 21 23 e 54 33 c 33 ...
- 监控和安全运维 1.7 nagios配置邮件告警
8. 配置邮件告警 服务端 vim /etc/nagios/objects/contacts.cfg 增加: define contact{ contact_name use generic-cont ...
- JAVA基础知识总结15(集合容器)
集合框架:用于存储数据的容器. 1:对象封装数据,对象多了也需要存储.集合用于存储对象. 2:对象的个数确定可以使用数组,但是不确定怎么办?可以用集合.因为集合是可变长度的. 集合和数组的区别: 1: ...