问题:最近在项目中遇到,不同客户机安装不同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

调用方法如下:

导出代码:

/// <summary>
/// DataTable导出到Excel的MemoryStream Export()
/// </summary>
/// <param name="dtSource">DataTable数据源</param>
/// <param name="strHeaderText">Excel表头文本(例如:车辆列表)</param>
public static MemoryStream Export(DataTable dtSource, string strHeaderText)
{
HSSFWorkbook workbook = new HSSFWorkbook();
ISheet sheet = workbook.CreateSheet(); #region 右击文件 属性信息
{
DocumentSummaryInformation dsi = PropertySetFactory.CreateDocumentSummaryInformation();
dsi.Company = "NPOI";
workbook.DocumentSummaryInformation = dsi; SummaryInformation si = PropertySetFactory.CreateSummaryInformation();
si.Author = "文件作者信息"; //填加xls文件作者信息
si.ApplicationName = "创建程序信息"; //填加xls文件创建程序信息
si.LastAuthor = "最后保存者信息"; //填加xls文件最后保存者信息
si.Comments = "作者信息"; //填加xls文件作者信息
si.Title = "标题信息"; //填加xls文件标题信息
si.Subject = "主题信息";//填加文件主题信息
si.CreateDateTime = System.DateTime.Now;
workbook.SummaryInformation = si;
}
#endregion ICellStyle dateStyle = workbook.CreateCellStyle();
IDataFormat format = workbook.CreateDataFormat();
dateStyle.DataFormat = format.GetFormat("yyyy-mm-dd"); //取得列宽
int[] arrColWidth = new int[dtSource.Columns.Count];
foreach (DataColumn item in dtSource.Columns)
{
arrColWidth[item.Ordinal] = Encoding.GetEncoding(936).GetBytes(item.ColumnName.ToString()).Length;
}
for (int i = 0; i < dtSource.Rows.Count; i++)
{
for (int j = 0; j < dtSource.Columns.Count; j++)
{
int intTemp = Encoding.GetEncoding(936).GetBytes(dtSource.Rows[i][j].ToString()).Length;
if (intTemp > arrColWidth[j])
{
arrColWidth[j] = intTemp;
}
}
}
int rowIndex = 0;
foreach (DataRow row in dtSource.Rows)
{
#region 新建表,填充表头,填充列头,样式
if (rowIndex == 65535 || rowIndex == 0)
{
if (rowIndex != 0)
{
sheet = workbook.CreateSheet();
} #region 表头及样式
{
IRow headerRow = sheet.CreateRow(0);
headerRow.HeightInPoints = 25;
headerRow.CreateCell(0).SetCellValue(strHeaderText); ICellStyle headStyle = workbook.CreateCellStyle();
headStyle.Alignment = HorizontalAlignment.CENTER;
IFont font = workbook.CreateFont();
font.FontHeightInPoints = 20;
font.Boldweight = 700;
headStyle.SetFont(font);
headerRow.GetCell(0).CellStyle = headStyle;
sheet.AddMergedRegion(new NPOI.SS.Util.CellRangeAddress(0, 0, 0, dtSource.Columns.Count - 1));
}
#endregion #region 列头及样式
{
IRow headerRow = sheet.CreateRow(1);
ICellStyle headStyle = workbook.CreateCellStyle();
headStyle.Alignment = HorizontalAlignment.CENTER;
IFont font = workbook.CreateFont();
font.FontHeightInPoints = 10;
font.Boldweight = 700;
headStyle.SetFont(font);
foreach (DataColumn column in dtSource.Columns)
{
headerRow.CreateCell(column.Ordinal).SetCellValue(column.ColumnName);
headerRow.GetCell(column.Ordinal).CellStyle = headStyle; //设置列宽
sheet.SetColumnWidth(column.Ordinal, (arrColWidth[column.Ordinal] + 1) * 256);
}
}
#endregion rowIndex = 2;
}
#endregion #region 填充内容
IRow dataRow = sheet.CreateRow(rowIndex);
foreach (DataColumn column in dtSource.Columns)
{
ICell newCell = dataRow.CreateCell(column.Ordinal); string drValue = row[column].ToString(); switch (column.DataType.ToString())
{
case "System.String"://字符串类型
newCell.SetCellValue(drValue);
break;
case "System.DateTime"://日期类型
System.DateTime dateV;
System.DateTime.TryParse(drValue, out dateV);
newCell.SetCellValue(dateV); newCell.CellStyle = dateStyle;//格式化显示
break;
case "System.Boolean"://布尔型
bool boolV = false;
bool.TryParse(drValue, out boolV);
newCell.SetCellValue(boolV);
break;
case "System.Int16"://整型
case "System.Int32":
case "System.Int64":
case "System.Byte":
int intV = 0;
int.TryParse(drValue, out intV);
newCell.SetCellValue(intV);
break;
case "System.Decimal"://浮点型
case "System.Double":
double doubV = 0;
double.TryParse(drValue, out doubV);
newCell.SetCellValue(doubV);
break;
case "System.DBNull"://空值处理
newCell.SetCellValue("");
break;
default:
newCell.SetCellValue("");
break;
}
}
#endregion rowIndex++;
}
using (MemoryStream ms = new MemoryStream())
{
workbook.Write(ms);
ms.Flush();
ms.Position = 0;
sheet.Dispose();
return ms;
}
}

  导入代码:

/// <summary>
/// 读取excel ,默认第一行为标头
/// </summary>
/// <param name="strFileName">excel文档路径</param>
/// <returns></returns>
public static DataTable Import(string strFileName)
{
DataTable dt = new DataTable(); HSSFWorkbook hssfworkbook;
using (FileStream file = new FileStream(strFileName, FileMode.Open, FileAccess.Read))
{
hssfworkbook = new HSSFWorkbook(file);
}
ISheet sheet = hssfworkbook.GetSheetAt();
System.Collections.IEnumerator rows = sheet.GetRowEnumerator(); IRow headerRow = sheet.GetRow();
int cellCount = headerRow.LastCellNum; for (int j = ; j < cellCount; j++)
{
ICell cell = headerRow.GetCell(j);
dt.Columns.Add(cell.ToString());
} for (int i = (sheet.FirstRowNum + ); i <= sheet.LastRowNum; i++)
{
IRow row = sheet.GetRow(i);
DataRow dataRow = dt.NewRow(); for (int j = row.FirstCellNum; j < cellCount; j++)
{
if (row.GetCell(j) != null)
dataRow[j] = row.GetCell(j).ToString();
} dt.Rows.Add(dataRow);
}
return dt;
}

问题:最近在项目中遇到,不同客户机安装不同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. 导出

[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. Metasploit 使用简介

    Metasploit Framework 是非常优秀的开源渗透测试框架,像我这样的菜鸟刚刚听说,于是花时间好好研究了一下,整理了一下学习笔记,贴出来和大家一起交流.第一次写文章又不足的地方大家多多指点 ...

  2. Project facet Java version 1.8 is not supported.

    Eclipse中添加项目到Servers中时提示“Project facet Java version 1.8 is not supported.” 解决方案:方法一:选中项目,右键roperties ...

  3. css3中自定义 placeholder 文本颜色

    对于 ie 浏览器我们可以通过自定义的 class 名称,直接修改 span 这个标签的样式.对于其他浏览器诸如谷歌和火狐就需要特殊处理了,不多说直接上代码: ::-webkit-input-plac ...

  4. watch和computed的用法区别是什么?

    在模板中绑定表达式是非常便利的,但是它们实际上只用于简单的操作.模板是为了描述视图的结构.在模板中放入太多的逻辑会让模板过重且难以维护.这就是为什么 Vue.js 将绑定表达式限制为一个表达式.如果需 ...

  5. 内存保护机制及绕过方法——通过伪造SEHOP链绕过SEHOP保护机制

    1.1    SEHOP保护机制 1.1.1    SEHOP工作原理: SEHOP保护机制的核心就是检查SEH链的完整性,其验证代码如下: BOOL RtlIsValidHandler(handle ...

  6. 重置input checked

    <!-- 作者:duke 时间:2018-10-24 描述: 重置input 样式--> <!DOCTYPE HTML><html> <head> &l ...

  7. 职责链模式(Chain of Responsibility)

    一.责任链模式介绍 责任链模式:将能够处理同一类请求的对象连成一条链,使这些对象都有机会处理请求,所提交的请求沿着链传递.从而避免请求的 发送者和接受者之间的耦合关系.链上的对象逐个判断是否有能力处理 ...

  8. 【LeetCode 88_数组】Merge Sorted Array

    void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) { ; ; ; &&a ...

  9. 三张图看懂 clientheight、offsetheight、scrollheight

    clientheight clientheigh: 内容的可视区域,不包含border. clientheight=padding + height - 横向滚动轴高度. The Element.cl ...

  10. EasyPusher RTSP推流/EasyRTMP RTMP推流Android安卓摄像头视频偏暗的问题解决方案

    本文转自EasyDarwin团队成员JOHN的博客:http://blog.csdn.net/jyt0551/article/details/75730226 在我们测试EasyPusher/Easy ...