OpenXml操作Excel
要使用OpenXml首先要下载最新的Open XML Format SDK 2.0。具体的导入openxml的dll,去网上搜,很多
1.我个人写的XmlHelp类
using System; using System.Collections.Generic; using System.Linq; using System.Reflection; using System.Data; using System.Text; using DocumentFormat.OpenXml; using DocumentFormat.OpenXml.Packaging; using DocumentFormat.OpenXml.Spreadsheet; namespace CreateExcelSpreadsheet { public class ExcelHelper { /// <summary> /// 获取指定单元格的值 /// </summary> /// <param name="cell">单元格</param> /// <param name="stringTablePart">SharedStringTablePart类型</param> /// <returns></returns> public static string GetValue(Cell cell, SharedStringTablePart stringTablePart) { string returnStr = string.Empty; try { if (cell.ChildElements.Count == 0) return null; returnStr = cell.CellValue.InnerText; if ((cell.DataType != null) && (cell.DataType == CellValues.SharedString)) returnStr = stringTablePart.SharedStringTable.ChildElements[Int32.Parse(returnStr)].InnerText; } catch (Exception ex) { //returnStr = ex.Message; throw ex; } return returnStr; } /// <summary> /// 获取指定的行 /// </summary> /// <param name="worksheet"></param> /// <param name="rowIndex">行号</param> /// <returns></returns> public static Row GetRow(WorkbookPart workBook,Worksheet worksheet,int rowIndex) { return worksheet.GetFirstChild<SheetData>(). Elements<Row>().Where(r => r.RowIndex == rowIndex).First(); } /// <summary> /// 根据行,列获取指定的单元格 /// </summary> /// <param name="worksheet"></param> /// <param name="rowIndex">行号</param> /// <param name="columnName">列名</param> /// <returns></returns> public static Cell GetCell(WorkbookPart workBook,Worksheet worksheet, int rowIndex, string columnName) { Row row = GetRow(workBook,worksheet, rowIndex); if (row == null) return null; return row.Elements<Cell>().Where(c => string.Compare (c.CellReference.Value, columnName + rowIndex, true) == 0).First(); } /// <summary> /// 给指定的单元格赋值 /// </summary> /// <param name="cell"></param> /// <param name="newValue">所要赋值的数据</param> public static string SetValue(Cell cell, object newValue) { string returnStr = string.Empty; try { CellValue v = new CellValue(newValue.ToString()); cell.CellValue = v; } catch (Exception ex) { //returnStr = ex.Message; throw ex; } return returnStr; } /// <summary> /// 更新指定行,列的单元格的值 /// </summary> /// <param name="workSheet"></param> /// <param name="newValue">所要赋值的数据</param> /// <param name="rowIndex">行号</param> /// <param name="columnName">列名</param> public static string SetValue(WorkbookPart workBook, Worksheet workSheet, object newValue, int rowIndex, string columnName) { string returnStr = string.Empty; try{ Cell cell = GetCell(workBook,workSheet, rowIndex, columnName); cell.CellValue = new CellValue(newValue.ToString()); cell.DataType = new EnumValue<CellValues>(CellValues.Number); workSheet.Save(); }catch(Exception ex){ //returnStr = ex.Message; throw ex; } return returnStr; } /// <summary> /// 提起Worksheet的指定Row 作为DataTable的列名 /// </summary> /// <param name="dt"></param> /// <param name="workSheet"></param> /// <param name="row"></param> public static string GetDataTableColumn(ref DataTable dt,WorkbookPart workBook,Worksheet worksheet,Row row) { string returnStr = string.Empty; try { DataColumn dc = new DataColumn(); // SharedStringTable sst = workbookPart.SharedStringTablePart.SharedStringTable ; foreach (Cell cell in row) { string cellValue = GetValue(cell, workBook.SharedStringTablePart); dc = new DataColumn(cellValue); dt.Columns.Add(dc); } } catch (Exception ex) { //returnStr = ex.Message; throw ex; } return returnStr; } /// <summary> /// 把Worksheet中的数据一行一行的加进DataTable中 /// </summary> /// <param name="dt"></param> /// <param name="worksheet"></param> /// <param name="row"></param> public static string GetDataTableRow(ref DataTable dt,WorkbookPart workBook,Worksheet worksheet,Row row) { string returnStr = string.Empty; try { DataRow dr = dt.NewRow(); int i = 0; foreach (Cell cell in row) { string cellValue = GetValue(cell, workBook.SharedStringTablePart); dr[i++] = cellValue; } dt.Rows.Add(dr); } catch (Exception ex) { //returnStr = ex.Message; throw ex; } return returnStr; } /// <summary> /// 读取Excel的Sheet页到DataTable,默认Sheet的第一行是列名 /// </summary> /// <param name="workSheet"></param> /// <returns></returns> public static string GetDataTableBySheet(ref DataTable dt,WorkbookPart workBook, Worksheet workSheet) { string returnStr = string.Empty; try { IEnumerable<Row> rows = workSheet.Descendants<Row>(); foreach (Row row in rows) { if (row.RowIndex == 1) { //默认Sheet的第一行是列名 GetDataTableColumn(ref dt, workBook, workSheet, row); } else { GetDataTableRow(ref dt, workBook, workSheet, row); //更新除列名(第一行)以外的其他数据 } } } catch (Exception ex) { //returnStr = ex.Message; throw ex; } return returnStr; } /// <summary> /// 更新Worksheet中与DataTable相同的列 /// </summary> /// <param name="dt">传入的DataTable的值</param> /// <param name="workSheet"></param> public static string UpdateDataFromDataTable(DataTable dt, WorkbookPart workBook, Worksheet workSheet) { string returnStr = string.Empty; try { int i = 0; //workSheet的Row int j = 0; //dt.Rows的Row foreach (Row row_ws in workSheet){ i++; Cell cell_workSheet = GetCell(workBook,workSheet,i,"ID"); string cell_workSheet_value = GetValue(cell_workSheet,workBook.SharedStringTablePart) ; foreach (DataRow row_dt in dt.Rows) { j++; if (cell_workSheet_value == row_dt["ID"].ToString()) { SetValue(workBook,workSheet,row_dt["Name"],i,"Name"); } } } } catch (Exception ex) { returnStr = ex.Message; } return returnStr; } } }
2.具体应用例子
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using DocumentFormat.OpenXml; using DocumentFormat.OpenXml.Wordprocessing; using DocumentFormat.OpenXml.Packaging; using DocumentFormat.OpenXml.Spreadsheet; using DocumentFormat.OpenXml.Extensions; using CreateExcelSpreadsheet; namespace ConsoleApplication3 { class Program { static void Main(string[] args) { using (SpreadsheetDocument spreedSheet = SpreadsheetDocument.Open(@"F:\test.xlsx", true)) { WorkbookPart workBook = spreedSheet.WorkbookPart; //自动计算 spreedSheet.WorkbookPart.Workbook.CalculationProperties.ForceFullCalculation = true; spreedSheet.WorkbookPart.Workbook.CalculationProperties.FullCalculationOnLoad = true; IEnumerable<Sheet> sheetXlsx = spreedSheet.WorkbookPart.Workbook.Descendants<Sheet>().Select(c=>c); ) { Console.WriteLine("Sheet页为空"); } else { //先去第一个Sheet做测试 WorksheetPart worksheetPart = workBook.WorksheetParts.FirstOrDefault(); // WorksheetPart worksheetPart = (WorksheetPart)spreedSheet.WorkbookPart.GetPartById(sheetXlsx.First().Id); Worksheet workWheet = worksheetPart.Worksheet; ExcelHelper.SetValue(workWheet, , "C"); } } } } }
以上代码简单明了,但是有个问题,就是,由于excel需要设置的属性很多,在使用OpenXml的时候,难免会后漏掉设置的属性,这样在用程序修改或者创建
excel后,第一次打开的时候,会弹出如下的消息,excel会自动补全确实的属性,目前我还没找到完美的解决方案,在随后会奉上
OpenXml操作Excel的更多相关文章
- 使用DocumentFormat.OpenXml操作Excel文件.xlsx
1.开始 DocumentFormat.OpenXml是ms官方给一个操作office三大件新版文件格式(.xlsx,.docx,.pptx)的组件:特色是它定义了OpenXml所包含的所有对象(たぶ ...
- C# - openxml 操作excel - '“System.IO.Packaging.Package”在未被引用的程序集中定义'
在 CodeProject中,有位网友写的一篇基于OpenXML SDK 2.0对excel(大数据量)进行操作,其中,运行的时候,有如下错误: 类型“System.IO.Packaging.Pack ...
- 使用OpenXml操作Excel,以下方法用于在添加列时修改Cell的CellReference属性。
以下方法实现了递增Excel中单元格的CellReference的功能,只支持两位字母. public static string CellReferenceIncrement(string cell ...
- Open XML操作Excel导入数据
项目中发现使用OleDb(using System.Data.OleDb)相关对象处理Excel导入功能,不是很稳定经常出问题,需要把这个问题解决掉.项目组提出使用OpenXML来处理Excel的导入 ...
- C# 操作 Excel 常见问题收集和整理(定期更新,欢迎交流)
经常会有项目需要把表格导出为 Excel 文件,或者是导入一份 Excel 来操作,那么如何在 C# 中操作 Excel 文件成了一个最基本的问题. 做开发这几年来,陆陆续续也接触过这样的需求,但因为 ...
- 使用OpenXML将Excel内容读取到DataTable中
前言:前面的几篇文章简单的介绍了如何使用OpenXML创建Excel文档.由于在平时的工作中需要经常使用到Excel的读写操作,简单的介绍下使用 OpenXML读取Excel中得数据.当然使用Open ...
- 转-C# 操作 Excel 常见问题收集和整理
经常会有项目需要把表格导出为 Excel 文件,或者是导入一份 Excel 来操作,那么如何在 C# 中操作 Excel 文件成了一个最基本的问题. 做开发这几年来,陆陆续续也接触过这样的需求,但因为 ...
- C# 操作 Excel 常见问题收集和整理
C# 操作 Excel 常见问题收集和整理(定期更新,欢迎交流) 经常会有项目需要把表格导出为 Excel 文件,或者是导入一份 Excel 来操作,那么如何在 C# 中操作 Excel 文件成了一个 ...
- C#使用oledb操作excel文件的方法
本文实例讲述了C#使用oledb操作excel文件的方法.分享给大家供大家参考.具体分析如下: 不管什么编程语言都会提供操作Excel文件的方式,C#操作Excel主要有以下几种方式: 1.Excel ...
随机推荐
- java 如何下载jar包
随着maven工具的使用,我们已经不再需要辛苦的找jar包,也不需要再买会员去下载jar包,但是还有一些同学,不知道怎么下载jar包,下面我给大家介绍一下,如何潇洒的找到自己想要的jar包. 首先,访 ...
- SP16580 QTREE7 - Query on a tree VII
Description 一棵树,每个点初始有个点权和颜色(0/1) 0 u :询问所有u,v 路径上的最大点权,要满足u,v 路径上所有点的颜色都相同 1 u :反转u 的颜色 2 u w :把u 的 ...
- 有标号的DAG计数 III
Description 给定一正整数n,对n个点有标号的有向无环图进行计数,这里加一个限制:此图必须是弱连通图.输出答案 mod 10007 的结果. Solution 弱连通图即把边变成无向之后成为 ...
- [android] socket在手机上的应用
1.手机助手 1.1 USB链接 可以读取手机的PID和VID,确定唯一的设备,可以给手机安装对应的驱动等 socket在固定端口通信 1.2 WIFI链接 pc在电脑在整个网段发送UDP数据包,手机 ...
- 编写DBCP连接池
#配置数据库数据源package com.itang.utils; import java.io.InputStream; import java.sql.Connection; import jav ...
- java导入excle表格,并且对表格进行相应的修改,并对表格数据进行整理,最后导出本地表格等一系列操作
1.首先创建一个java项目 完成效果如下图所示 2.导入以下jar包 3.代码如下 其中行和列的操作是根据需求自动划分的 public class auto_date { private stati ...
- Eclipse使用快捷键总结
1.为方法添加注释:Alt + Shift + J
- javascript多浏览器的兼容
一.document.formName.item(”itemName”) 问题 问题说明:IE下,可以使用 document.formName.item(”itemName”) 或 document. ...
- Visual Studio Code使用Open In Browser打开的是记事本
今天在家里学习前端开发,发现Visual Studio Code使用Open In Browser插件快速打开浏览器有问题,打开的是操作系统的记事本. 后来发现电脑的html文件默打开方式被改成了记事 ...
- 使用SlidingPaneLayout 实现仿微信的滑动返回
上周,公司的项目改版要求加上一个右滑返回上一个界面,于是就在网上找了一些开源库打算实现.但是在使用的时候遇见了许多的问题.试了两天用过 https://github.com/ikew0ng/Swipe ...