要使用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的更多相关文章

  1. 使用DocumentFormat.OpenXml操作Excel文件.xlsx

    1.开始 DocumentFormat.OpenXml是ms官方给一个操作office三大件新版文件格式(.xlsx,.docx,.pptx)的组件:特色是它定义了OpenXml所包含的所有对象(たぶ ...

  2. C# - openxml 操作excel - '“System.IO.Packaging.Package”在未被引用的程序集中定义'

    在 CodeProject中,有位网友写的一篇基于OpenXML SDK 2.0对excel(大数据量)进行操作,其中,运行的时候,有如下错误: 类型“System.IO.Packaging.Pack ...

  3. 使用OpenXml操作Excel,以下方法用于在添加列时修改Cell的CellReference属性。

    以下方法实现了递增Excel中单元格的CellReference的功能,只支持两位字母. public static string CellReferenceIncrement(string cell ...

  4. Open XML操作Excel导入数据

    项目中发现使用OleDb(using System.Data.OleDb)相关对象处理Excel导入功能,不是很稳定经常出问题,需要把这个问题解决掉.项目组提出使用OpenXML来处理Excel的导入 ...

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

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

  6. 使用OpenXML将Excel内容读取到DataTable中

    前言:前面的几篇文章简单的介绍了如何使用OpenXML创建Excel文档.由于在平时的工作中需要经常使用到Excel的读写操作,简单的介绍下使用 OpenXML读取Excel中得数据.当然使用Open ...

  7. 转-C# 操作 Excel 常见问题收集和整理

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

  8. C# 操作 Excel 常见问题收集和整理

    C# 操作 Excel 常见问题收集和整理(定期更新,欢迎交流) 经常会有项目需要把表格导出为 Excel 文件,或者是导入一份 Excel 来操作,那么如何在 C# 中操作 Excel 文件成了一个 ...

  9. C#使用oledb操作excel文件的方法

    本文实例讲述了C#使用oledb操作excel文件的方法.分享给大家供大家参考.具体分析如下: 不管什么编程语言都会提供操作Excel文件的方式,C#操作Excel主要有以下几种方式: 1.Excel ...

随机推荐

  1. Java入门系列-18-抽象类和接口

    抽象类 在第16节继承中,有父类 People People people=new People(); people.sayHi(); 实例化People是没有意义的,因为"人"是 ...

  2. imx6. android6.0经常修改或者用到的目录(未完)

    系统应用apk存放的文件: out/target/product/sabresd_6dq/system/app 系统配置存放目录:(我自己的,也许不对) out/target/product/sabr ...

  3. js事件绑定简单写法

    $E.on = function (o, e, f) { return o.addEventListener ? o.addEventListener(e, f, false) : o.attachE ...

  4. C# Winform软件多语言(汉语、英语。。。)界面的切换,低耦合

    Winform软件多语言切换,个人见解,降低软件对语言展示的耦合度. 1.设计图(自己瞎画的呵呵) 2.做的小demo,界面如下 3.下面是代码展示部分 1)Form1代码展示 namespace W ...

  5. 静态代码块,构造代码块,main()

    静态代码块 随Class 加载而加载,为Class 作初始化: 在main() 之前加载: 只执行一次: 构造代码块 随对象的创建而加载,为对象作初始化 public class day04 { pu ...

  6. Gradle sync failed: Cannot set the value of read-only property 'outputFile'

    错误 Gradle sync failed: Cannot set the value of read-only property 'outputFile' 原因 gradle打包,自定义apk名称代 ...

  7. SQL SEVERE 基本用法 1

    知识点: 数据库的存储结构分为逻辑存储结构和物理存储结构两种, 其中逻辑存储结构指是由那些信息组成,物理存储结构是指如何在磁盘上存储数据库文件的. 数据库文件由数据文件和事务日志文件组成,一个数据库至 ...

  8. thinkphp的删除操作

    1.循环遍历要删除的用户的或者呀删除的文章的id值: <volist name="list" id="vo"> <tr id="si ...

  9. The method setItems(String) in the type ForTokensTag is not applicable for the arguments (Object)

    1. 问题 看到这个错误以为是貌似jsp页面有误,c:forTokens标签用错了?? An error occurred at line: in the jsp file: /WEB-INF/pag ...

  10. javascript判断一个元素是另外一个元素的子元素

    javascript判断一个元素是另外一个元素的子元素用途有很多,最常用的就是当点击页面的空白处去执行某些操作,比如弹出层等. function isParent (obj,parentObj){ w ...