问题:最近在项目中遇到,不同客户机安装不同Office版本,在导出Excel时,发生错误。

找不到Excel Com组件,错误信息如下。

未能加载文件或程序集“Microsoft.Office.Interop.Excel, Version=12.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c”或它的某一个依赖项。系统找不到指定的文件。

解决方法:

  1.引用高版本的的Excel.dll组件,最新版本14.0.0 防止客户安装高版本如Office不能导出。

  (DLL组件可以兼容低版本,不能兼容高版本)

2.右键DLL属性,将引用的Excel.dll组件,嵌入互操作类型为True,特定版本=false .这一步非常关键。

    嵌入互操作类型 改成True后,生成时可能现有调用Excel的代码会报错,引用Microsoft.CSharp 命名空间,可以解决此问题。

3.引用Excel 14.0.0 DLL组件方法,vs2012 右键添加引用->程序集->扩展->Microsoft.Office.Interop.Excel

  Excel.dll     http://files.cnblogs.com/files/ichk/Microsoft.Office.Interop.Excel.rar

其他方法:

  1.使用NPOI.DLL开源组件,可以不安装Office软件,进行读写Excel文件。

  NPIO.dll     http://files.cnblogs.com/files/ichk/NPOI.rar

调用方法如下:

导出代码:

  1. /// <summary>
  2. /// DataTable导出到Excel的MemoryStream Export()
  3. /// </summary>
  4. /// <param name="dtSource">DataTable数据源</param>
  5. /// <param name="strHeaderText">Excel表头文本(例如:车辆列表)</param>
  6. public static MemoryStream Export(DataTable dtSource, string strHeaderText)
  7. {
  8. HSSFWorkbook workbook = new HSSFWorkbook();
  9. ISheet sheet = workbook.CreateSheet();
  10.  
  11. #region 右击文件 属性信息
  12. {
  13. DocumentSummaryInformation dsi = PropertySetFactory.CreateDocumentSummaryInformation();
  14. dsi.Company = "NPOI";
  15. workbook.DocumentSummaryInformation = dsi;
  16.  
  17. SummaryInformation si = PropertySetFactory.CreateSummaryInformation();
  18. si.Author = "文件作者信息"; //填加xls文件作者信息
  19. si.ApplicationName = "创建程序信息"; //填加xls文件创建程序信息
  20. si.LastAuthor = "最后保存者信息"; //填加xls文件最后保存者信息
  21. si.Comments = "作者信息"; //填加xls文件作者信息
  22. si.Title = "标题信息"; //填加xls文件标题信息
  23. si.Subject = "主题信息";//填加文件主题信息
  24. si.CreateDateTime = System.DateTime.Now;
  25. workbook.SummaryInformation = si;
  26. }
  27. #endregion
  28.  
  29. ICellStyle dateStyle = workbook.CreateCellStyle();
  30. IDataFormat format = workbook.CreateDataFormat();
  31. dateStyle.DataFormat = format.GetFormat("yyyy-mm-dd");
  32.  
  33. //取得列宽
  34. int[] arrColWidth = new int[dtSource.Columns.Count];
  35. foreach (DataColumn item in dtSource.Columns)
  36. {
  37. arrColWidth[item.Ordinal] = Encoding.GetEncoding(936).GetBytes(item.ColumnName.ToString()).Length;
  38. }
  39. for (int i = 0; i < dtSource.Rows.Count; i++)
  40. {
  41. for (int j = 0; j < dtSource.Columns.Count; j++)
  42. {
  43. int intTemp = Encoding.GetEncoding(936).GetBytes(dtSource.Rows[i][j].ToString()).Length;
  44. if (intTemp > arrColWidth[j])
  45. {
  46. arrColWidth[j] = intTemp;
  47. }
  48. }
  49. }
  50. int rowIndex = 0;
  51. foreach (DataRow row in dtSource.Rows)
  52. {
  53. #region 新建表,填充表头,填充列头,样式
  54. if (rowIndex == 65535 || rowIndex == 0)
  55. {
  56. if (rowIndex != 0)
  57. {
  58. sheet = workbook.CreateSheet();
  59. }
  60.  
  61. #region 表头及样式
  62. {
  63. IRow headerRow = sheet.CreateRow(0);
  64. headerRow.HeightInPoints = 25;
  65. headerRow.CreateCell(0).SetCellValue(strHeaderText);
  66.  
  67. ICellStyle headStyle = workbook.CreateCellStyle();
  68. headStyle.Alignment = HorizontalAlignment.CENTER;
  69. IFont font = workbook.CreateFont();
  70. font.FontHeightInPoints = 20;
  71. font.Boldweight = 700;
  72. headStyle.SetFont(font);
  73. headerRow.GetCell(0).CellStyle = headStyle;
  74. sheet.AddMergedRegion(new NPOI.SS.Util.CellRangeAddress(0, 0, 0, dtSource.Columns.Count - 1));
  75. }
  76. #endregion
  77.  
  78. #region 列头及样式
  79. {
  80. IRow headerRow = sheet.CreateRow(1);
  81. ICellStyle headStyle = workbook.CreateCellStyle();
  82. headStyle.Alignment = HorizontalAlignment.CENTER;
  83. IFont font = workbook.CreateFont();
  84. font.FontHeightInPoints = 10;
  85. font.Boldweight = 700;
  86. headStyle.SetFont(font);
  87. foreach (DataColumn column in dtSource.Columns)
  88. {
  89. headerRow.CreateCell(column.Ordinal).SetCellValue(column.ColumnName);
  90. headerRow.GetCell(column.Ordinal).CellStyle = headStyle;
  91.  
  92. //设置列宽
  93. sheet.SetColumnWidth(column.Ordinal, (arrColWidth[column.Ordinal] + 1) * 256);
  94. }
  95. }
  96. #endregion
  97.  
  98. rowIndex = 2;
  99. }
  100. #endregion
  101.  
  102. #region 填充内容
  103. IRow dataRow = sheet.CreateRow(rowIndex);
  104. foreach (DataColumn column in dtSource.Columns)
  105. {
  106. ICell newCell = dataRow.CreateCell(column.Ordinal);
  107.  
  108. string drValue = row[column].ToString();
  109.  
  110. switch (column.DataType.ToString())
  111. {
  112. case "System.String"://字符串类型
  113. newCell.SetCellValue(drValue);
  114. break;
  115. case "System.DateTime"://日期类型
  116. System.DateTime dateV;
  117. System.DateTime.TryParse(drValue, out dateV);
  118. newCell.SetCellValue(dateV);
  119.  
  120. newCell.CellStyle = dateStyle;//格式化显示
  121. break;
  122. case "System.Boolean"://布尔型
  123. bool boolV = false;
  124. bool.TryParse(drValue, out boolV);
  125. newCell.SetCellValue(boolV);
  126. break;
  127. case "System.Int16"://整型
  128. case "System.Int32":
  129. case "System.Int64":
  130. case "System.Byte":
  131. int intV = 0;
  132. int.TryParse(drValue, out intV);
  133. newCell.SetCellValue(intV);
  134. break;
  135. case "System.Decimal"://浮点型
  136. case "System.Double":
  137. double doubV = 0;
  138. double.TryParse(drValue, out doubV);
  139. newCell.SetCellValue(doubV);
  140. break;
  141. case "System.DBNull"://空值处理
  142. newCell.SetCellValue("");
  143. break;
  144. default:
  145. newCell.SetCellValue("");
  146. break;
  147. }
  148. }
  149. #endregion
  150.  
  151. rowIndex++;
  152. }
  153. using (MemoryStream ms = new MemoryStream())
  154. {
  155. workbook.Write(ms);
  156. ms.Flush();
  157. ms.Position = 0;
  158. sheet.Dispose();
  159. return ms;
  160. }
  161. }

  导入代码:

  1. /// <summary>
  2. /// 读取excel ,默认第一行为标头
  3. /// </summary>
  4. /// <param name="strFileName">excel文档路径</param>
  5. /// <returns></returns>
  6. public static DataTable Import(string strFileName)
  7. {
  8. DataTable dt = new DataTable();
  9.  
  10. HSSFWorkbook hssfworkbook;
  11. using (FileStream file = new FileStream(strFileName, FileMode.Open, FileAccess.Read))
  12. {
  13. hssfworkbook = new HSSFWorkbook(file);
  14. }
  15. ISheet sheet = hssfworkbook.GetSheetAt();
  16. System.Collections.IEnumerator rows = sheet.GetRowEnumerator();
  17.  
  18. IRow headerRow = sheet.GetRow();
  19. int cellCount = headerRow.LastCellNum;
  20.  
  21. for (int j = ; j < cellCount; j++)
  22. {
  23. ICell cell = headerRow.GetCell(j);
  24. dt.Columns.Add(cell.ToString());
  25. }
  26.  
  27. for (int i = (sheet.FirstRowNum + ); i <= sheet.LastRowNum; i++)
  28. {
  29. IRow row = sheet.GetRow(i);
  30. DataRow dataRow = dt.NewRow();
  31.  
  32. for (int j = row.FirstCellNum; j < cellCount; j++)
  33. {
  34. if (row.GetCell(j) != null)
  35. dataRow[j] = row.GetCell(j).ToString();
  36. }
  37.  
  38. dt.Rows.Add(dataRow);
  39. }
  40. return dt;
  41. }

问题:最近在项目中遇到,不同客户机安装不同Office版本,在导出Excel时,发生错误。

找不到Excel Com组件,错误信息如下。

未能加载文件或程序集“Microsoft.Office.Interop.Excel, Version=12.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c”或它的某一个依赖项。系统找不到指定的文件。

解决方法:

  1.引用高版本的的Excel.dll组件,最新版本14.0.0 防止客户安装高版本如Office不能导出。

  (DLL组件可以兼容低版本,不能兼容高版本)

2.右键DLL属性,将引用的Excel.dll组件,嵌入互操作类型为True,特定版本=false .这一步非常关键。

    嵌入互操作类型 改成True后,生成时可能现有调用Excel的代码会报错,引用Microsoft.CSharp 命名空间,可以解决此问题。

3.引用Excel 14.0.0 DLL组件方法,vs2012 右键添加引用->程序集->扩展->Microsoft.Office.Interop.Excel

  Excel.dll     http://files.cnblogs.com/files/ichk/Microsoft.Office.Interop.Excel.rar

其他方法:

  1.使用NPOI.DLL开源组件,可以不安装Office软件,进行读写Excel文件。

  NPIO.dll     http://files.cnblogs.com/files/ichk/NPOI.rar

调用方法如下:

导出代码:

[csharp] view plain copy

 
  1. /// <summary>
  2. /// DataTable导出到Excel的MemoryStream Export()
  3. /// </summary>
  4. /// <param name="dtSource">DataTable数据源</param>
  5. /// <param name="strHeaderText">Excel表头文本(例如:车辆列表)</param>
  6. public static MemoryStream Export(DataTable dtSource, string strHeaderText)
  7. {
  8. HSSFWorkbook workbook = new HSSFWorkbook();
  9. ISheet sheet = workbook.CreateSheet();
  10. #region 右击文件 属性信息
  11. {
  12. DocumentSummaryInformation dsi = PropertySetFactory.CreateDocumentSummaryInformation();
  13. dsi.Company = "NPOI";
  14. workbook.DocumentSummaryInformation = dsi;
  15. SummaryInformation si = PropertySetFactory.CreateSummaryInformation();
  16. si.Author = "文件作者信息"; //填加xls文件作者信息
  17. si.ApplicationName = "创建程序信息"; //填加xls文件创建程序信息
  18. si.LastAuthor = "最后保存者信息"; //填加xls文件最后保存者信息
  19. si.Comments = "作者信息"; //填加xls文件作者信息
  20. si.Title = "标题信息"; //填加xls文件标题信息
  21. si.Subject = "主题信息";//填加文件主题信息
  22. si.CreateDateTime = System.DateTime.Now;
  23. workbook.SummaryInformation = si;
  24. }
  25. #endregion
  26. ICellStyle dateStyle = workbook.CreateCellStyle();
  27. IDataFormat format = workbook.CreateDataFormat();
  28. dateStyle.DataFormat = format.GetFormat("yyyy-mm-dd");
  29. //取得列宽
  30. int[] arrColWidth = new int[dtSource.Columns.Count];
  31. foreach (DataColumn item in dtSource.Columns)
  32. {
  33. arrColWidth[item.Ordinal] = Encoding.GetEncoding(936).GetBytes(item.ColumnName.ToString()).Length;
  34. }
  35. for (int i = 0; i < dtSource.Rows.Count; i++)
  36. {
  37. for (int j = 0; j < dtSource.Columns.Count; j++)
  38. {
  39. int intTemp = Encoding.GetEncoding(936).GetBytes(dtSource.Rows[i][j].ToString()).Length;
  40. if (intTemp > arrColWidth[j])
  41. {
  42. arrColWidth[j] = intTemp;
  43. }
  44. }
  45. }
  46. int rowIndex = 0;
  47. foreach (DataRow row in dtSource.Rows)
  48. {
  49. #region 新建表,填充表头,填充列头,样式
  50. if (rowIndex == 65535 || rowIndex == 0)
  51. {
  52. if (rowIndex != 0)
  53. {
  54. sheet = workbook.CreateSheet();
  55. }
  56. #region 表头及样式
  57. {
  58. IRow headerRow = sheet.CreateRow(0);
  59. headerRow.HeightInPoints = 25;
  60. headerRow.CreateCell(0).SetCellValue(strHeaderText);
  61. ICellStyle headStyle = workbook.CreateCellStyle();
  62. headStyle.Alignment = HorizontalAlignment.CENTER;
  63. IFont font = workbook.CreateFont();
  64. font.FontHeightInPoints = 20;
  65. font.Boldweight = 700;
  66. headStyle.SetFont(font);
  67. headerRow.GetCell(0).CellStyle = headStyle;
  68. sheet.AddMergedRegion(new NPOI.SS.Util.CellRangeAddress(0, 0, 0, dtSource.Columns.Count - 1));
  69. }
  70. #endregion
  71. #region 列头及样式
  72. {
  73. IRow headerRow = sheet.CreateRow(1);
  74. ICellStyle headStyle = workbook.CreateCellStyle();
  75. headStyle.Alignment = HorizontalAlignment.CENTER;
  76. IFont font = workbook.CreateFont();
  77. font.FontHeightInPoints = 10;
  78. font.Boldweight = 700;
  79. headStyle.SetFont(font);
  80. foreach (DataColumn column in dtSource.Columns)
  81. {
  82. headerRow.CreateCell(column.Ordinal).SetCellValue(column.ColumnName);
  83. headerRow.GetCell(column.Ordinal).CellStyle = headStyle;
  84. //设置列宽
  85. sheet.SetColumnWidth(column.Ordinal, (arrColWidth[column.Ordinal] + 1) * 256);
  86. }
  87. }
  88. #endregion
  89. rowIndex = 2;
  90. }
  91. #endregion
  92. #region 填充内容
  93. IRow dataRow = sheet.CreateRow(rowIndex);
  94. foreach (DataColumn column in dtSource.Columns)
  95. {
  96. ICell newCell = dataRow.CreateCell(column.Ordinal);
  97. string drValue = row[column].ToString();
  98. switch (column.DataType.ToString())
  99. {
  100. case "System.String"://字符串类型
  101. newCell.SetCellValue(drValue);
  102. break;
  103. case "System.DateTime"://日期类型
  104. System.DateTime dateV;
  105. System.DateTime.TryParse(drValue, out dateV);
  106. newCell.SetCellValue(dateV);
  107. newCell.CellStyle = dateStyle;//格式化显示
  108. break;
  109. case "System.Boolean"://布尔型
  110. bool boolV = false;
  111. bool.TryParse(drValue, out boolV);
  112. newCell.SetCellValue(boolV);
  113. break;
  114. case "System.Int16"://整型
  115. case "System.Int32":
  116. case "System.Int64":
  117. case "System.Byte":
  118. int intV = 0;
  119. int.TryParse(drValue, out intV);
  120. newCell.SetCellValue(intV);
  121. break;
  122. case "System.Decimal"://浮点型
  123. case "System.Double":
  124. double doubV = 0;
  125. double.TryParse(drValue, out doubV);
  126. newCell.SetCellValue(doubV);
  127. break;
  128. case "System.DBNull"://空值处理
  129. newCell.SetCellValue("");
  130. break;
  131. default:
  132. newCell.SetCellValue("");
  133. break;
  134. }
  135. }
  136. #endregion
  137. rowIndex++;
  138. }
  139. using (MemoryStream ms = new MemoryStream())
  140. {
  141. workbook.Write(ms);
  142. ms.Flush();
  143. ms.Position = 0;
  144. sheet.Dispose();
  145. return ms;
  146. }
  147. }

导入代码:

[csharp] view plain copy

 
  1. /// <summary>
  2. /// 读取excel ,默认第一行为标头
  3. /// </summary>
  4. /// <param name="strFileName">excel文档路径</param>
  5. /// <returns></returns>
  6. public static DataTable Import(string strFileName)
  7. {
  8. DataTable dt = new DataTable();
  9. HSSFWorkbook hssfworkbook;
  10. using (FileStream file = new FileStream(strFileName, FileMode.Open, FileAccess.Read))
  11. {
  12. hssfworkbook = new HSSFWorkbook(file);
  13. }
  14. ISheet sheet = hssfworkbook.GetSheetAt(0);
  15. System.Collections.IEnumerator rows = sheet.GetRowEnumerator();
  16. IRow headerRow = sheet.GetRow(0);
  17. int cellCount = headerRow.LastCellNum;
  18. for (int j = 0; j < cellCount; j++)
  19. {
  20. ICell cell = headerRow.GetCell(j);
  21. dt.Columns.Add(cell.ToString());
  22. }
  23. for (int i = (sheet.FirstRowNum + 1); i <= sheet.LastRowNum; i++)
  24. {
  25. IRow row = sheet.GetRow(i);
  26. DataRow dataRow = dt.NewRow();
  27. for (int j = row.FirstCellNum; j < cellCount; j++)
  28. {
  29. if (row.GetCell(j) != null)
  30. dataRow[j] = row.GetCell(j).ToString();
  31. }
  32. dt.Rows.Add(dataRow);
  33. }
  34. return dt;
  35. }

2.使用C#发射方式调用Excel进行,不需要引用Excel.dll组件。此种方法不建议,太麻烦,也需要安装Office。

调用方法如下:

[csharp] view plain copy

 
  1. private void Export2Excel(DataGridView datagridview, bool captions)
  2. {
  3. object objApp_Late;
  4. object objBook_Late;
  5. object objBooks_Late;
  6. object objSheets_Late;
  7. object objSheet_Late;
  8. object objRange_Late;
  9. object[] Parameters;
  10. string[] headers = new string[datagridview.DisplayedColumnCount(true)];
  11. string[] columns = new string[datagridview.DisplayedColumnCount(true)];
  12. string[] colName = new string[datagridview.DisplayedColumnCount(true)];
  13. int i = 0;
  14. int c = 0;
  15. int m = 0;
  16. for (c = 0; c < datagridview.Columns.Count; c++)
  17. {
  18. for (int j = 0; j < datagridview.Columns.Count; j++)
  19. {
  20. DataGridViewColumn tmpcol = datagridview.Columns[j];
  21. if (tmpcol.DisplayIndex == c)
  22. {
  23. if (tmpcol.Visible) //不显示的隐藏列初始化为tag=0
  24. {
  25. headers[c - m] = tmpcol.HeaderText;
  26. i = c - m + 65;
  27. columns[c - m] = Convert.ToString((char)i);
  28. colName[c - m] = tmpcol.Name;
  29. }
  30. else
  31. {
  32. m++;
  33. }
  34. break;
  35. }
  36. }
  37. }
  38. try
  39. {
  40. // Get the class type and instantiate Excel.
  41. Type objClassType;
  42. objClassType = Type.GetTypeFromProgID("Excel.Application");
  43. objApp_Late = Activator.CreateInstance(objClassType);
  44. //Get the workbooks collection.
  45. objBooks_Late = objApp_Late.GetType().InvokeMember("Workbooks", BindingFlags.GetProperty, null, objApp_Late, null);
  46. //Add a new workbook.
  47. objBook_Late = objBooks_Late.GetType().InvokeMember("Add", BindingFlags.InvokeMethod, null, objBooks_Late, null);
  48. //Get the worksheets collection.
  49. objSheets_Late = objBook_Late.GetType().InvokeMember("Worksheets", BindingFlags.GetProperty, null, objBook_Late, null);
  50. //Get the first worksheet.
  51. Parameters = new Object[1];
  52. Parameters[0] = 1;
  53. objSheet_Late = objSheets_Late.GetType().InvokeMember("Item", BindingFlags.GetProperty, null, objSheets_Late, Parameters);
  54. if (captions)
  55. {
  56. // Create the headers in the first row of the sheet
  57. for (c = 0; c < datagridview.DisplayedColumnCount(true); c++)
  58. {
  59. //Get a range object that contains cell.
  60. Parameters = new Object[2];
  61. Parameters[0] = columns[c] + "1";
  62. Parameters[1] = Missing.Value;
  63. objRange_Late = objSheet_Late.GetType().InvokeMember("Range", BindingFlags.GetProperty, null, objSheet_Late, Parameters);
  64. //Write Headers in cell.
  65. Parameters = new Object[1];
  66. Parameters[0] = headers[c];
  67. objRange_Late.GetType().InvokeMember("Value", BindingFlags.SetProperty, null, objRange_Late, Parameters);
  68. }
  69. }
  70. // Now add the data from the grid to the sheet starting in row 2
  71. for (i = 0; i < datagridview.RowCount; i++)
  72. {
  73. c = 0;
  74. foreach (string txtCol in colName)
  75. {
  76. DataGridViewColumn col = datagridview.Columns[txtCol];
  77. if (col.Visible)
  78. {
  79. //Get a range object that contains cell.
  80. Parameters = new Object[2];
  81. Parameters[0] = columns[c] + Convert.ToString(i + 2);
  82. Parameters[1] = Missing.Value;
  83. objRange_Late = objSheet_Late.GetType().InvokeMember("Range", BindingFlags.GetProperty, null, objSheet_Late, Parameters);
  84. //Write Headers in cell.
  85. Parameters = new Object[1];
  86. //Parameters[0] = datagridview.Rows[i].Cells[headers[c]].Value.ToString();
  87. Parameters[0] = datagridview.Rows[i].Cells[col.Name].Value.ToString();
  88. objRange_Late.GetType().InvokeMember("Value", BindingFlags.SetProperty, null, objRange_Late, Parameters);
  89. c++;
  90. }
  91. }
  92. }
  93. //Return control of Excel to the user.
  94. Parameters = new Object[1];
  95. Parameters[0] = true;
  96. objApp_Late.GetType().InvokeMember("Visible", BindingFlags.SetProperty,
  97. null, objApp_Late, Parameters);
  98. objApp_Late.GetType().InvokeMember("UserControl", BindingFlags.SetProperty,
  99. null, objApp_Late, Parameters);
  100. }
  101. catch (Exception theException)
  102. {
  103. String errorMessage;
  104. errorMessage = "Error: ";
  105. errorMessage = String.Concat(errorMessage, theException.Message);
  106. errorMessage = String.Concat(errorMessage, " Line: ");
  107. errorMessage = String.Concat(errorMessage, theException.Source);
  108. MessageBox.Show(errorMessage, "Error");
  109. }
  110. }
[csharp] view plain copy

 
  1. 导出
  1.  
[csharp] view plain copy

 
  1. System.Type ExcelType = System.Type.GetTypeFromProgID("Excel.Application");
  2. Microsoft.Office.Interop.Excel.Application obj = Activator.CreateInstance(ExcelType) as Microsoft.Office.Interop.Excel.Application;

让C# Excel导入导出,支持不同版本的Office(转)的更多相关文章

  1. excel导入 导出 兼容各个版本服务器不装EXCEL也可以

    给出 demo源码: http://pan.baidu.com/s/1hqGMudY 提取码:pw4n首先要引用 NPOI.dll (可在网上下载!) //导入 public void OnSubmi ...

  2. 土制Excel导入导出及相关问题探讨

    转载请注明出处https://www.cnblogs.com/funnyzpc/p/10392085.html 新的一年,又一个开始,不见收获,却见年龄,好一个猪年,待我先来一首里尔克的诗: < ...

  3. Java 使用 Jxl 实现 Excel 导入导出

    开发过程中经常需要用到数据的导入导出功能,之前用的是POI,这次使用JXL,JXL相对于POI来说要轻量简洁许多,在数据量不大的情况下还是非常实用的.这里做一下使用JXL的学习记录.首先需要导入相应的 ...

  4. java jxl excel 导入导出的 总结(建立超链接,以及目录sheet的索引)

    最近项目要一个批量导出功能,而且要生成一个单独的sheet页,最后后面所有sheet的索引,并且可以点击进入连接.网上搜索了一下,找到一个方法,同时把相关的excel导入导出操作记录一下!以便以后使用 ...

  5. Java Excel 导入导出(一)

    本文主要描述通过java实现Excel导入导出 一.读写Excel三种常用方式 1.JXL——Java Excel开放源码项目:读取,创建,更新 2.POI——Apache POI ,提供API给Ja ...

  6. Excel导入导出工具(简单、好用且轻量级的海量Excel文件导入导出解决方案.)

    Excel导入导出工具(简单.好用且轻量级的海量Excel文件导入导出解决方案.) 置顶 2019-09-07 16:47:10 $9420 阅读数 261更多 分类专栏: java   版权声明:本 ...

  7. 如何自动化你的Excel导入导出(Java)?

    GitHub | 中文 | English | 博客 为什么使用AutoExcel? Excel导入导出在软件开发中非常常见,只要你接触过开发,就一定会遇到.相信很多人会跟我一样选择用Apache P ...

  8. 关于Excel导入导出的用例设计

    目前,为方便操作,很多系统都会增加批量导入导出的功能.文件导入导出一般格式都是excel.由于用户直接在excel在填写内容,无法控制填写的格 式,加上excel解析比较困难,所以一般涉及到excel ...

  9. ASP.NET 之 常用类、方法的超级总结,并包含动态的EXCEL导入导出功能,奉上类库源码

    实用类:UtilityClass 包含如下方法 判断对象是否为空或NULL,如果是空或NULL返回true,否则返回false 验证手机号是否正确 13,15,18 验证邮箱 验证网址 MD5加密,返 ...

  10. 一个基于POI的通用excel导入导出工具类的简单实现及使用方法

    前言: 最近PM来了一个需求,简单来说就是在录入数据时一条一条插入到系统显得非常麻烦,让我实现一个直接通过excel导入的方法一次性录入所有数据.网上关于excel导入导出的例子很多,但大多相互借鉴. ...

随机推荐

  1. ansible入门一(Ansible介绍及安装部署)

    本节内容: 运维工具 Ansible特性 Ansible架构图和核心组件 安装Ansible 演示使用示例 一.运维工具 作为一个Linux运维人员,需要了解大量的运维工具,并熟知这些工具的差异,能够 ...

  2. JavaScript---forEach( ) 、map( )和 filter()

    循环数组,最先想到的就是for循环:  for(var i=0;i<count;i++) { //逻辑代码} 除此之外,就是forEach()方法了. Firefox 和Chrome 的Arra ...

  3. centos 7 nginx 远程无法访问的原因

    1.购买的阿里云需要添加安全组 80端口就可以用了 2.检查防火墙是否关闭 systemctl stop firewalld 这点很重要 我就是查了一天才发现centos7 防火墙开着 难怪几把搞 如 ...

  4. CF 916

    题解: 首先看题目 A题看不懂... 花了5分钟才做出来 还wa了 B题 一看好像是堆+位运算? 然后A了样例 C题 wa了好激发 似乎加边加错了 然后看D,似乎是可持久化平衡树? 我又不会... E ...

  5. PHP获取随机数的函数rand()和mt_rand()

    rand()函数用户获取随机数,具体用法如下: rand()可以设置0个参数或者两个参数,如rand($min,$max),$min表示从XX开始取值,$max表示最大只能为XX 例如: <?p ...

  6. APUE学习笔记——3.10文件共享

    基本概念 内核使用3个数据结构描述一个打开的文件:进程表.文件表.V节点表 首先了解3种数据结构的概念     1 进程表         每一个进程有一个进程表.进程表里是一组打开的文件描述符,如标 ...

  7. 使用jQuery操作DOM(2)

    1.获取设置属性值 attr({属性名1:属性值1,属性名2:属性值2}); //设置属性值 removeAttr(“属性名”); //删除属性 注意:如果元素没有此属性,会不起作用 2.获取同辈元素 ...

  8. d3.js(v5.7)力导向图(关系图谱)

    先上图,后面再一一解释: ok,为了方便理解,这里我就没有用之前封装的automatch函数来将数据和节点匹配了,如果你对enter(),exit()函数还不是很理解的话,请移步至我之前写的<n ...

  9. 每周荐书:云原生、Docker、Web算法(评论送书)

    每周荐书:云原生.Docker.Web算法(评论送书) 感谢大家对每周荐书栏目的支持,先公布下上周中奖名单 名优秀评论可以免费获得此书.   云原生应用架构实践 云原生架构,关注简化开发流程.提升研发 ...

  10. 前端构建工具-fis3使用入门

    FIS3 是面向前端的工程构建工具.解决前端工程中性能优化.资源加载(异步.同步.按需.预加载.依赖管理.合并.内嵌).模块化开发.自动化工具.开发规范.代码部署等问题. 官网地址是: https:/ ...