C#使用ClosedXML进行读写excel操作
作者:MartinYangHJ
项目简介
ClosedXML是.NET平台上的一款开源库,它使得程序员能够方便地创建、读取和修改Excel文件(.xlsx格式)。无需直接与Microsoft Office Interop进行交互, ClosedXML提供了一种轻量级且高性能的方式来处理Excel数据,兼容.NET Framework及.NET Core。
技术分析
易用性:ClosedXML提供了清晰、直观的API,使得创建表格、设置样式、插入公式等操作变得简单。例如,只需几行代码就能创建一个新的工作簿并填充数据:
using (var workbook = new XLWorkbook())
{
var worksheet = workbook.Worksheets.Add("Sample Sheet");
worksheet.Cell("A1").Value = "Hello";
worksheet.Cell("B1").Value = "World";
workbook.SaveAs("HelloWorld.xlsx");
}
性能优化:ClosedXML通过内存映射文件和延迟计算策略提高了性能,这意味着直到需要时才会计算或写入数据,减少了不必要的资源消耗。
功能全面:ClosedXML支持处理复杂的Excel功能,如图表、数据验证、条件格式化、超链接等。此外,还支持读取和写入数据表以及处理大型数据集。
版本兼容性:该库已适配.NET Framework 4.0+ 和 .NET Core,确保了跨平台的兼容性和未来发展的潜力。
社区活跃:ClosedXML有一个活跃的开发团队和社区,不断修复bug、添加新功能,并对用户反馈作出积极回应。
应用场景
数据报表生成:快速将数据库数据导出到Excel,生成自定义模板的报表。
文件解析:用于读取现有的Excel文件,提取其中的数据进行分析或导入到其他系统。
前端下载功能:配合Web应用,允许用户下载自定义的Excel文件。
特点
简洁API:使代码更易于编写和理解。
强大性能:避免了对Office Interop的依赖,提高了运行速度和内存效率。
完整性:覆盖了大部分Excel的功能特性。
可扩展性:允许自定义样式和行为以满足特定需求。
跨平台支持:可以在Windows、Linux和macOS上运行。
C#使用ClosedXML读写excel
首先使用NuGet安装ClosedXML,然后在程序中添加引用ClosedXML.Excel;
1.导出数据到Excel
public void ExportToExcel(DataTable dt)
{
using (var workbook = new XLWorkbook())
{
if (dt.TableName == "") dt.TableName = "sheet1";
var worksheet = workbook.Worksheets.Add(dt.TableName);
var header = worksheet.FirstRow();
for (int i = 0; i < dt.Columns.Count; ++i)
{
worksheet.Cell(1, i + 1).Value = dt.Columns[i].ColumnName;
worksheet.Cell(1, i + 1).Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
worksheet.Cell(1, i + 1).Style.Alignment.Vertical = XLAlignmentVerticalValues.Center;
}
for (int i = 0; i < dt.Rows.Count; ++i)
{
for (int j = 0; j < dt.Columns.Count; ++j)
{
worksheet.Cell(i + 2, j + 1).Value = dt.Rows[i][j].ToString();
worksheet.Cell(i + 2, j + 1).Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
worksheet.Cell(i + 2, j + 1).Style.Alignment.Vertical = XLAlignmentVerticalValues.Center;
}
}
workbook.SaveAs(sfd.FileName);
}
}2.从Excel读取数据
public DataTable ImportExcelToDataTable(string filepath)
{
DataTable dt = new DataTable();
DataColumn dataColumn=new DataColumn("columnName1");
dt.Columns.Add(dataColumn);
dataColumn=new DataColumn("columnName2");
dt.Columns.Add(dataColumn);
dataColumn=new DataColumn("columnName3");
dt.Columns.Add(dataColumn);
dataColumn=new DataColumn("columnName4");
dt.Columns.Add(dataColumn);
using (XLWorkbook workBook = new XLWorkbook(filepath))
{
IXLWorksheet workSheet = workBook.Worksheet(1);
bool isFirstRow = true;
foreach (var row in workSheet.Rows())
{
if (isFirstRow)
{
isFirstRow = false;
continue;
}
else
{
dt.Rows.Add();
int i = 0;
foreach (IXLCell cell in row.Cells())
{
if(i>dt.Columns.Count-1)
{
break;
}
dt.Rows[dt.Rows.Count - 1][i] = cell.Value.ToString();
i++;
}
}
}
}
return dt;
}3.读取内容映射到DataTable
using ClosedXML.Excel;
using DocumentFormat.OpenXml.Office2010.ExcelAc;
using DocumentFormat.OpenXml.Spreadsheet;
using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
public class ExcelReader
{
/// <summary>
/// 读取 Excel 文件内容并返回包含多个工作表的 Dictionary 列表
/// </summary>
/// <param name="excelFilePath">Excel 文件路径</param>
/// <param name="sheetNames">需要读取的工作表名称列表</param>
/// <returns>工作表:工作表数据</returns>
public Dictionary<string, DataTable> ReadExcel(string excelFilePath, List<string> sheetNames)
{
Dictionary<string, DataTable> result = new Dictionary<string, DataTable>();
try
{
using (var workbook = new XLWorkbook(excelFilePath))
{
// 遍历所有需要读取的工作表
foreach (var sheetName in sheetNames)
{
// 判断工作表是否存在
if (workbook.Worksheets.Contains(sheetName))
{
var worksheet = workbook.Worksheet(sheetName);
DataTable dataTable = ConvertWorksheetToDataTable(worksheet);
result.Add(sheetName, dataTable);
}
else
{
Console.WriteLine($"工作表 {sheetName} 不存在!");
}
}
}
}
catch (Exception ex)
{
Console.WriteLine($"读取 Excel 文件时发生错误: {ex.Message}");
}
return result;
}
/// <summary>
/// 将工作表转换为 DataTable
/// </summary>
/// <param name="worksheet">工作表</param>
/// <returns>转换后的 DataTable</returns>
private DataTable ConvertWorksheetToDataTable(IXLWorksheet worksheet)
{
DataTable dataTable = new DataTable();
bool isHeaderRow = true;
// 遍历工作表的每一行
foreach (var row in worksheet.Rows())
{
if (isHeaderRow)
{
// 第一个非空单元格是列头
foreach (var cell in row.Cells())
{
dataTable.Columns.Add(cell.Value.ToString());
}
isHeaderRow = false;
}
else
{
// 每一行对应 DataTable 的一行
DataRow dataRow = dataTable.NewRow();
int columnIndex = 0;
foreach (var cell in row.Cells())
{
dataRow[columnIndex] = cell.Value.ToString();
columnIndex++;
}
dataTable.Rows.Add(dataRow);
}
}
return dataTable;
}
}
public class Program
{
public static void Main()
{
string excelFilePath = @"C:\Users\Mike\Desktop\Demo.xlsx";
List<string> sheetNames = new List<string> { "导入", "导入2" };
ExcelReader excelReader = new ExcelReader();
var result = excelReader.ReadExcel(excelFilePath, sheetNames);
foreach (var item in result)
{
Console.WriteLine($"工作表:{item.Key}");
var dt = item.Value;
foreach (DataRow row in dt.Rows)
{
//打印该行的第一列、第二列、第三列的内容
Console.WriteLine($"{row[0]}_{row[1]}_{row[2]}");
}
Console.WriteLine();
}
}
}4.读取Sheet名称列表
class Program
{
static void Main()
{
string filePath = "C:\\Users\\XCKJ\\Desktop\\导入.xlsx"; // 请替换为你文件的路径
var list = GetSheetNameList(filePath);// 获取所有工作表(sheet)名称
}
private static List<string> GetSheetNameList(string filePath)
{
// 打开 Excel 文件
using (var workbook = new XLWorkbook(filePath))
{
// 获取所有工作表(sheet)名称
List<string> sheetNames = new List<string>();
foreach (var worksheet in workbook.Worksheets)
{
sheetNames.Add(worksheet.Name);
}
return sheetNames;
}
}
}到此这篇关于C#使用ClosedXML进行读写excel操作的文章就介绍到这了,更多相关C# ClosedXML读写excel内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
