1. using System;
  2. using System.Data;
  3. using System.IO;
  4. using System.Runtime.InteropServices;
  5. using System.Threading;
  6. using System.Windows.Forms;
  7. using Microsoft.Office.Core;
  8. using Excel = Microsoft.Office.Interop.Excel;
  9.  
  10. namespace WindowsFormsApplication1
  11. {
  12. public partial class Form1 : Form
  13. {
  14. private bool isStartPrint = false;
  15.  
  16. public Form1()
  17. {
  18. InitializeComponent();
  19. }
  20.  
  21. private void button1_Click(object sender, EventArgs e)
  22. {
  23. //string OriginalPath = Path.GetDirectoryName(Application.ExecutablePath) + "\\IMS.accdb";
  24. ////初始化数据库
  25. //DataBase.OleDbObject.InitDatabase(OriginalPath);
  26. //DataBase.OleDbObject.OpenDb();
  27. //int k=DataBase.OleDbObject.Select("select * from ElementInventory").Rows.Count;
  28.  
  29. //初始化要写入Excel的数据
  30. DataTable dt = new DataTable();
  31. for (int i = ; i < ; i++)
  32. {
  33. DataColumn dc = new DataColumn();
  34. dc.ColumnName = "name" + i;
  35. dc.DataType = typeof(string);
  36. dt.Columns.Add(dc);
  37. }
  38. for (int i = ; i < ; i++)
  39. {
  40. DataRow dr = dt.NewRow();
  41. if (i % == )
  42. {
  43. dr[] = "测试用例" + i + "号,开始测试是否自动换行,以及页面高度自适应。";
  44. }
  45. else
  46. {
  47. dr[] = "测试用例" + i + "号";
  48. }
  49. for (int j = ; j < ; j++)
  50. {
  51. dr[j] = j;
  52. }
  53. dt.Rows.Add(dr);
  54. }
  55. if (!isStartPrint)
  56. {
  57. Thread th = new Thread(delegate ()
  58. {
  59. DataTabletoExcel(dt, "测试.xlsx");
  60. });
  61. th.Start();
  62. isStartPrint = true;
  63. }
  64. else
  65. {
  66. MessageBox.Show("打印程序已启用,请稍后……", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
  67. }
  68. //DataTabletoExcel(dt, "测试.xlsx");
  69. }
  70.  
  71. public void DataTabletoExcel(System.Data.DataTable dtTemp, string strFileName)
  72. {
  73. int rowNum = dtTemp.Rows.Count; //先得到dtTemp的行数
  74. int columnNum = dtTemp.Columns.Count; //列数
  75. Excel.Application ExcelApp = new Excel.Application(); //声明一个应用程序类实例
  76.  
  77. //ExcelApp.DefaultFilePath = ""; //默认文件路径导出excel的路径还是在参数strFileName里设置
  78. //ExcelApp.DisplayAlerts = true;
  79. //ExcelApp.SheetsInNewWorkbook = 1;///返回或设置 Microsoft Excel 自动插入到新工作簿中的工作表数目。
  80. Excel.Workbook worksBook = ExcelApp.Workbooks.Add(); //创建一个新工作簿
  81. Excel.Worksheet workSheet = (Excel.Worksheet)worksBook.Worksheets[]; //在工作簿中得到sheet。
  82. if (workSheet == null)
  83. {
  84. System.Diagnostics.Debug.WriteLine("ERROR: worksheet == null");
  85. return;
  86. }
  87. workSheet.Name = "测试Sheet1"; //工作表的名称
  88. workSheet.Cells.WrapText = true; //设置所有列的文本自动换行
  89. workSheet.Cells.EntireRow.AutoFit(); //设置所有列自动调整行高
  90. #region 绘制列
  91. ///自定义方法,向sheet中绘制列
  92. RangeMark(workSheet, "A1", "A2", "合并竖列1");
  93. RangeMark(workSheet, "B1", "B2", "合并竖列2");
  94. RangeMark(workSheet, "C1", "C2", "合并竖列3");
  95. RangeMark(workSheet, "D1", "D2", "合并竖列4");
  96. RangeMark(workSheet, "E1", "E2", "合并竖列5");
  97. RangeMark(workSheet, "F1", "H1", "合并横行1");
  98. RangeMark(workSheet, "F2", "F2", "合并横行1.1");
  99. RangeMark(workSheet, "G2", "G2", "合并横行1.2");
  100. RangeMark(workSheet, "H2", "H2", "合并横行1.3");
  101. RangeMark(workSheet, "I1", "K1", "合并横行2");
  102. RangeMark(workSheet, "I2", "J2", "合并横行2.1");
  103. RangeMark(workSheet, "K2", "K2", "合并横行2.2");
  104. #endregion
  105. //将DataTable中的数据导入Excel中
  106. for (int i = ; i < rowNum; i++)
  107. {
  108. for (int j = ; j < columnNum; j++)
  109. {
  110. workSheet.Cells[i + , j + ] = dtTemp.Rows[i][j].ToString(); //文本
  111.  
  112. }
  113. }
  114. ///保存路径
  115. string filePath = @"C:\Users\Admin\Desktop\" + strFileName;
  116. if (File.Exists(filePath))
  117. {
  118. try
  119. {
  120. File.Delete(filePath);
  121. }
  122. catch (Exception)
  123. {
  124.  
  125. }
  126. }
  127. ExcelApp.Visible = true;
  128. //------------------------打印页面相关设置--------------------------------
  129. workSheet.PageSetup.PaperSize = Excel.XlPaperSize.xlPaperA4;//纸张大小
  130. workSheet.PageSetup.Orientation = Excel.XlPageOrientation.xlLandscape;//页面横向
  131. //workSheet.PageSetup.Zoom = 75; //打印时页面设置,缩放比例百分之几
  132. workSheet.PageSetup.Zoom = false; //打印时页面设置,必须设置为false,页高,页宽才有效
  133. workSheet.PageSetup.FitToPagesWide = ; //设置页面缩放的页宽为1页宽
  134. workSheet.PageSetup.FitToPagesTall = false; //设置页面缩放的页高自动
  135. workSheet.PageSetup.LeftHeader = "Nigel";//页面左上边的标志
  136. workSheet.PageSetup.CenterFooter = " &P 页,共 &N ";//页面下标
  137. workSheet.PageSetup.PrintGridlines = true; //打印单元格网线
  138. workSheet.PageSetup.TopMargin = 1.5 / 0.035; //上边距为2cm(转换为in)
  139. workSheet.PageSetup.BottomMargin = 1.5 / 0.035; //下边距为1.5cm
  140. workSheet.PageSetup.LeftMargin = / 0.035; //左边距为2cm
  141. workSheet.PageSetup.RightMargin = / 0.035; //右边距为2cm
  142. workSheet.PageSetup.CenterHorizontally = true; //文字水平居中
  143. //------------------------打印页面设置结束--------------------------------
  144. ///http://blog.csdn.net/wanmingtom/article/details/6125599
  145. worksBook.PrintPreview(); //打印预览
  146. //worksBook.PrintOutEx(); //直接打印
  147. //worksBook.Close(); //关闭工作空间
  148. //ExcelApp.Quit(); //退出程序
  149. //workSheet.SaveAs(filePath); //另存表
  150. KillProcess(ExcelApp); //杀掉生成的进程
  151. isStartPrint = false; //打印完毕
  152. GC.Collect(); //垃圾回收机制
  153. }
  154. /// <summary>
  155. /// 引用Windows句柄,获取程序PID
  156. /// </summary>
  157. /// <param name="Hwnd"></param>
  158. /// <param name="PID"></param>
  159. /// <returns></returns>
  160. [DllImport("User32.dll")]
  161. public static extern int GetWindowThreadProcessId(IntPtr Hwnd, out int PID);
  162. /// <summary>
  163. /// 杀掉生成的进程
  164. /// </summary>
  165. /// <param name="AppObject">进程程对象</param>
  166. private static void KillProcess(Excel.Application AppObject)
  167. {
  168. int Pid = ;
  169. IntPtr Hwnd = new IntPtr(AppObject.Hwnd);
  170. System.Diagnostics.Process p = null;
  171. try
  172. {
  173. GetWindowThreadProcessId(Hwnd, out Pid);
  174. p = System.Diagnostics.Process.GetProcessById(Pid);
  175. if (p != null)
  176. {
  177. p.Kill();
  178. p.Dispose();
  179. }
  180. }
  181. catch (Exception ex)
  182. {
  183. System.Diagnostics.Debug.WriteLine("进程关闭失败!异常信息:" + ex);
  184. }
  185. }
  186.  
  187. /// <summary>
  188. /// 创建表头单元格,包括合并单元格
  189. /// </summary>
  190. /// <param name="workSheet">工作表</param>
  191. /// <param name="startCell">单元格起始格编号</param>
  192. /// <param name="endCell">单元格结束编号</param>
  193. /// <param name="strText">单元格名称</param>
  194. private static bool RangeMark(Excel.Worksheet workSheet, string startCell, string endCell, string strText)
  195. {
  196. //创建一个区域对象。第一个参数是开始格子号,第二个参数是终止格子号。比如选中A1——D3这个区域。
  197. Excel.Range range = (Excel.Range)workSheet.get_Range(startCell, endCell);
  198. if (range == null)
  199. {
  200. System.Diagnostics.Debug.WriteLine("ERROR: range == null");
  201. return false;
  202. }
  203. range.Merge(); //合并方法,0的时候直接合并为一个单元格
  204. range.Font.Size = ; //字体大小
  205. range.Font.Name = "黑体"; //字体
  206. range.WrapText = true; //文本自动换行
  207. range.EntireRow.AutoFit(); //自动调整行高
  208. //range.RowHeight = 20;
  209. //range.EntireColumn.AutoFit(); //自动调整列宽
  210. range.ColumnWidth = ;
  211. range.HorizontalAlignment = XlVAlign.xlVAlignCenter; //横向居中
  212. range.Value = strText; //合并单元格之后,设置其中的文本
  213. range.Interior.ColorIndex = ; //填充颜色
  214. range.Cells.Borders.LineStyle = ; //设置单元格边框的粗细
  215.  
  216. return true;
  217. }
  218. }
  219. }

C#操作excel打印的更多相关文章

  1. unity3d 下操作excel 与打印

    原地址:http://www.colabug.com/thread-1146390-1-1.html 因项目需要,需在unity下实现写入excel.打印功能.因之前在winform里操作过excel ...

  2. 一个由正则表达式引发的血案 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. 一些特殊字符,如“&”,“- ...

  3. VB操作EXCEL文件

    用VB操作Excel(VB6.0)(整理) 首先创建Excel对象,使用ComObj:Dim ExcelID as Excel.ApplicationSet ExcelID as new Excel. ...

  4. Delphi操作Excel大全

    Delphi操作Excel大全 DELPHI操作excel(转)(一) 使用动态创建的方法 首先创建 Excel 对象,使用ComObj:var ExcelApp: Variant;ExcelApp ...

  5. VBS操作Excel常见方法

    VBS操作Excel常见方法 作者: 字体:[增加 减小] 类型:转载 时间:2009-11-13我要评论 VBS控制Excel常见方法,需要的朋友可以参考下. dim oExcel,oWb,oShe ...

  6. Ruby操作Excel的方法与技巧大全

    测试工作中,批量的数据通常会放到excel表格中,测试输出的数据写回表格中,这样输入输出易于管理,同时清晰明了 使用ruby来操作excel文件首先需要在脚本里包含以下语句 require'win32 ...

  7. C++ builder 操作Excel方法(据网上资料整理)

    c++ builder 操作Excel方法,下面是从网上找到的一些不错的方法,学习一下: 用OLE操作Excel(目前最全的资料)(04.2.19更新) 本文档部分资料来自互联网,大部分是ccrun( ...

  8. C#对Excel打印时,PageSetup 对象详解

    PageSetup 对象包含所有页面设置的属性(左边距.底部边距.纸张大小等).下面按“页面”.“页边距”.“页眉/页脚”.“工作表”和“无对应选项卡”五个类别,逐一介绍. 一.页面 与“页面”选项卡 ...

  9. C# 操作 Excel 常见问题收集和整理(定期更新,欢迎交流)

    经常会有项目需要把表格导出为 Excel 文件,或者是导入一份 Excel 来操作,那么如何在 C# 中操作 Excel 文件成了一个最基本的问题. 做开发这几年来,陆陆续续也接触过这样的需求,但因为 ...

随机推荐

  1. MySQL-事务的实现-redo

    MySQL中事务: 事务的实现:      ACID: 原子性(A : Atomicity) 一致性(C : consistency ) 隔离性(I : isolation) 持久性(D : dura ...

  2. 摆花 (DP动态规划)

    2012_p3 摆花 (flower.cpp/c/pas) 时间限制: 1 Sec  内存限制: 128 MB提交: 17  解决: 10[提交][状态][讨论版][命题人:外部导入] 题目描述 3. ...

  3. AngularJS:template2

    ylbtech-AngularJS: 1.返回顶部 1.   2. 2.返回顶部   3.返回顶部   4.返回顶部   5.返回顶部 1.   2.  6.返回顶部   作者:ylbtech出处:h ...

  4. PHP实现四种基本排序算法 得多消化消化

    1.冒泡排序 // 冒泡排序 思路分析:在要排序的一组数中,对当前还未排好的序列,从前往后对相邻的两个数依次进行比较和调整,让较大的数往下沉,较小的往上冒.即,每当两相邻的数比较后发现它们的排序与排序 ...

  5. mybatis 学习一 建立maven项目

    一.直接建立Maven项目方法 1.建立Maven项目 接下来使用Eclipse的maven构建一个web项目,以构建SpringMVC项目为例: 1.1 选择建立Maven Project 选择Fi ...

  6. C#字符串Split方法的误区

    string s = "aaa1bbb2ccc1ddd";        string[] ss = s.Split("12".ToCharArray()); ...

  7. babel-polyfill使用简介

    babel-polyfill介绍 简介 使用这个插件你可随心所欲的使用es6甚至更高版本的方法,这个插件自动转码 安装 这个插件必须在你的源码运行之前运行,所以必须安装成dependency npm ...

  8. oracle数据库中函数的递归调用

    如有下面的表结构AAAA,用一个字段prev_id表示记录的先后顺序,要对其排序,需要用的递归函数 ID PREV_ID CONT 99   a 23 54 d 21 23 e 54 33 c 33 ...

  9. 监控和安全运维 1.7 nagios配置邮件告警

    8. 配置邮件告警 服务端 vim /etc/nagios/objects/contacts.cfg 增加: define contact{ contact_name use generic-cont ...

  10. JAVA基础知识总结15(集合容器)

    集合框架:用于存储数据的容器. 1:对象封装数据,对象多了也需要存储.集合用于存储对象. 2:对象的个数确定可以使用数组,但是不确定怎么办?可以用集合.因为集合是可变长度的. 集合和数组的区别: 1: ...