C#利用Microsoft.Office.Interop.Excel导出数据到Excel

添加引用(VS2013位于C:\Program Files (x86)\Microsoft Visual Studio 12.0\Visual Studio Tools for Office\PIA\Office15文件夹下)

本案例是直接将DataTable里面的数据导入到Excel内,所以需将数据转换成DataTable数据类型才可以

using Microsoft.Office.Interop.Excel;
using System.Reflection;
public void DataTableToExcel(System.Data.DataTable dataTable, string strTitle, string[] strHead, int[] columnWidth)
{
	int nMax = dataTable.Rows.Count;
	int nMin = 0;
	int rowCount = nMax - nMin + 1;//总行数
	const int columnCount = 7;//总列数

	//创建Excel对象
	Microsoft.Office.Interop.Excel.Application excelApp = new Microsoft.Office.Interop.Excel.Application();
	//新建工作簿
	Workbook workBook = excelApp.Workbooks.Add(true);
	//新建工作表
	Worksheet worksheet = workBook.ActiveSheet as Microsoft.Office.Interop.Excel.Worksheet;

	////设置标题
	Microsoft.Office.Interop.Excel.Range titleRange = worksheet.Range[worksheet.Cells[1, 1], worksheet.Cells[1, columnCount]];//选取单元格

	titleRange.Merge(true);                                         //合并单元格
	titleRange.Value2 = strTitle;                                   //设置单元格内文本
	titleRange.Font.Name = "微软雅黑";                              //设置字体
	titleRange.Font.Size = 18;                                      //字体大小
	titleRange.Font.Bold = true;                                    //加粗显示
	titleRange.HorizontalAlignment = XlHAlign.xlHAlignCenter;       //水平居中
	titleRange.VerticalAlignment = XlVAlign.xlVAlignCenter;         //垂直居中
	titleRange.Borders.LineStyle = XlLineStyle.xlContinuous;        //设置边框
	titleRange.Borders.Weight = XlBorderWeight.xlThin;              //边框常规粗细

	//设置表头
	//string[] strHead = new string[columnCount] { "id", "productUid", "productBarcode", "checkData", "checkResult", "creater", "checkDate" };
	//int[] columnWidth = new int[columnCount] { 8, 24, 24, 22, 10, 14, 20 };
	for (int i = 0; i < columnCount; i++)
	{
		Microsoft.Office.Interop.Excel.Range headRange = worksheet.Cells[2, i + 1] as Microsoft.Office.Interop.Excel.Range;//获取表头单元格,不用标题则从1开始
		headRange.Value2 = strHead[i];                              //设置单元格文本
		headRange.Font.Name = "Consolas";                           //设置字体
		headRange.Font.Size = 13;                                   //字体大小
		headRange.Font.Bold = true;                                 //加粗显示
		headRange.HorizontalAlignment = XlHAlign.xlHAlignCenter;    //水平居中
		headRange.VerticalAlignment = XlVAlign.xlVAlignCenter;      //垂直居中
		headRange.ColumnWidth = columnWidth[i];                     //设置列宽
		headRange.Borders.LineStyle = XlLineStyle.xlContinuous;     //设置边框
		headRange.Borders.Weight = XlBorderWeight.xlThin;           //边框常规粗细
	}

	//设置每列格式
	for (int i = 0; i < columnCount; i++)
	{
		Microsoft.Office.Interop.Excel.Range contentRange = worksheet.Range[worksheet.Cells[2, i + 1], worksheet.Cells[rowCount - 1 + 3, i + 1]];//不用标题则从第二行开始
		contentRange.Font.Name = "Consolas";
		contentRange.Font.Size = 10;
		contentRange.HorizontalAlignment = XlHAlign.xlHAlignCenter; //水平居中
		contentRange.VerticalAlignment = XlVAlign.xlVAlignCenter;   //垂直居中
		contentRange.Borders.LineStyle = XlLineStyle.xlContinuous;  //设置边框
		contentRange.Borders.Weight = XlBorderWeight.xlThin;        //边框常规粗细
		contentRange.WrapText = true;                               //自动换行
		contentRange.NumberFormatLocal = "@";                       //文本格式
	}

	//填充数据
	for (int i = 0; i < dataTable.Rows.Count; i++)
	{
		DataRow row = dataTable.Rows[i];
		for (int j = 0; j < dataTable.Columns.Count; j++)
		{
			excelApp.Cells[i + 3, j + 1] = row[j].ToString();
		}
	}
	//设置Excel可见
	excelApp.Visible = true;
}
posted @ 2020-01-18 09:03  那人_那事  阅读(2325)  评论(0编辑  收藏  举报