513 lines
22 KiB
C#
513 lines
22 KiB
C#
using System;
|
||
using System.Collections.Generic;
|
||
using System.Text;
|
||
using System.Data;
|
||
using System.Diagnostics;
|
||
using System.Drawing;
|
||
using System.IO;
|
||
using System.Windows.Forms;
|
||
using NPOI;
|
||
using NPOI.HSSF.UserModel;
|
||
using NPOI.SS.UserModel;
|
||
using NPOI.XSSF.UserModel;
|
||
using Repository.Models;
|
||
|
||
namespace tpDomeWinAPP.Service
|
||
{
|
||
public static class ioExcel
|
||
{
|
||
|
||
/// <summary>
|
||
/// 將excel匯入到datatable
|
||
/// </summary>
|
||
/// <param name="nosqllist">存放資料庫取出的編號list</param>
|
||
/// <param name="msge">返回結果</param>
|
||
/// <returns>返回datatable</returns>
|
||
public static DataTable ExcelToDataTable(List<string> nosqllist, out string msge, out string filename)
|
||
{
|
||
bool isColumnName = true;//第一行是否是列名
|
||
msge = "0";
|
||
string filePath = "";//excel路徑
|
||
List<string> NoList = new List<string>();//儲存編號,防止重複
|
||
//開啟檔案對話方塊選擇檔案
|
||
OpenFileDialog file = new OpenFileDialog();
|
||
filename = string.Empty;
|
||
file.Filter = "Excel(*.xlsx)|*.xlsx|Excel(*.xls)|*.xls";
|
||
file.InitialDirectory = Environment.GetFolderPath(Environment.SpecialFolder.Desktop);
|
||
file.Multiselect = false;
|
||
if (file.ShowDialog() == DialogResult.OK)
|
||
{
|
||
filePath = file.FileName;
|
||
filename = file.FileName;
|
||
}
|
||
DataTable dataTable = null;
|
||
FileStream fs = null;
|
||
DataColumn column = null;
|
||
DataRow dataRow = null;
|
||
IWorkbook workbook = null;
|
||
ISheet sheet = null;
|
||
IRow row = null;
|
||
ICell cell = null;
|
||
IRow rowisrepeat = null;
|
||
ICell cellisrepeat = null;
|
||
int startRow = 0;
|
||
dataTable = new DataTable();
|
||
try
|
||
{
|
||
using (fs = File.OpenRead(filePath))
|
||
{
|
||
// 2007版本
|
||
if (filePath.IndexOf(".xlsx") > 0)
|
||
workbook = new XSSFWorkbook(fs);
|
||
// 2003版本
|
||
else if (filePath.IndexOf(".xls") > 0)
|
||
workbook = new HSSFWorkbook(fs);
|
||
int sheetSerial = -1;
|
||
|
||
#region 構建 datatable的列
|
||
column = new DataColumn("sheetname");
|
||
dataTable.Columns.Add(column);
|
||
column = new DataColumn("tag_name_zh");
|
||
dataTable.Columns.Add(column);
|
||
column = new DataColumn("old_tags");
|
||
dataTable.Columns.Add(column);
|
||
column = new DataColumn("new_tags");
|
||
dataTable.Columns.Add(column);
|
||
column = new DataColumn("floor");
|
||
dataTable.Columns.Add(column);
|
||
column = new DataColumn("device_name");
|
||
dataTable.Columns.Add(column);
|
||
column = new DataColumn("device_note");
|
||
dataTable.Columns.Add(column);
|
||
column = new DataColumn("device_type");
|
||
dataTable.Columns.Add(column);
|
||
column = new DataColumn("device_number");
|
||
dataTable.Columns.Add(column);
|
||
//if (isColumnName)
|
||
//{
|
||
// startRow = 1;//如果第一行是列名,則從第二行開始讀取
|
||
// for (int i = firstRow.FirstCellNum; i < cellCount; ++i)
|
||
// {
|
||
// cell = firstRow.GetCell(i);
|
||
// if (cell != null)
|
||
// {
|
||
// if (cell.StringCellValue != null)
|
||
// {
|
||
// column = new DataColumn(cell.StringCellValue);
|
||
// dataTable.Columns.Add(column);
|
||
// }
|
||
// }
|
||
// }
|
||
//}
|
||
//else
|
||
//{
|
||
// for (int i = firstRow.FirstCellNum; i < cellCount; ++i)
|
||
// {
|
||
// column = new DataColumn("column" + (i + 1));
|
||
// dataTable.Columns.Add(column);
|
||
// }
|
||
//}
|
||
#endregion
|
||
|
||
foreach (var item in workbook)
|
||
{
|
||
sheetSerial += 1;
|
||
if (sheetSerial < 2) continue;
|
||
|
||
if (workbook != null)
|
||
{
|
||
//sheet = workbook.GetSheetAt(0);//讀取第一個sheet,當然也可以迴圈讀取每個sheet
|
||
sheet = item;
|
||
|
||
if (sheet != null)
|
||
{
|
||
int rowCount = sheet.LastRowNum;//總行數
|
||
if (rowCount > 0)
|
||
{
|
||
IRow firstRow = sheet.GetRow(0);//第一行
|
||
|
||
if (firstRow == null) continue;
|
||
#region 判斷列名是否一致
|
||
|
||
//string[] exlist = GetStringNum();//得到定義的標題
|
||
//for (int i = 0; i < exlist.Length; i++)
|
||
//{
|
||
// if (Convert.ToString(firstRow.Cells[i]) != exlist[i])
|
||
// {
|
||
// msge = "第" + i + 1 + "列標題不是" + exlist[i] + ",列標題錯誤!";
|
||
// return dataTable;
|
||
// }
|
||
//}
|
||
#endregion
|
||
|
||
//int cellCount = firstRow.LastCellNum;//列數
|
||
|
||
#region 判斷編號是否有重複
|
||
//NoList = nosqllist;
|
||
//for (int i = startRow; i <= rowCount; ++i)
|
||
//{
|
||
// rowisrepeat = sheet.GetRow(i);
|
||
// if (rowisrepeat == null) continue;
|
||
// cellisrepeat = rowisrepeat.GetCell(13);
|
||
// string noisrpt = Convert.ToString(cellisrepeat);
|
||
// if (!NoList.Contains(noisrpt))
|
||
// {
|
||
// NoList.Add(noisrpt);
|
||
// }
|
||
// else
|
||
// {
|
||
// msge = "編號:" + noisrpt + "重複,插入失敗,請確定編號唯一、無重複!";
|
||
// return dataTable;
|
||
// }
|
||
//}
|
||
#endregion
|
||
|
||
if (firstRow.Cells.Count >=6 )
|
||
{
|
||
// MessageBox.Show("firstRow.Cells.Count = "+ firstRow.Cells.Count.ToString());
|
||
|
||
if (firstRow.Cells[2].ToString() == "tags name" && firstRow.Cells[3].ToString() == "New Tagname")
|
||
{
|
||
#region 填充行
|
||
for (int i = startRow; i <= rowCount; ++i)
|
||
{
|
||
if (i == 0) continue; //第一行是欄位 不使用
|
||
row = sheet.GetRow(i);
|
||
if (row == null) continue;
|
||
|
||
if (row.GetCell(2) == null || string.IsNullOrEmpty(row.GetCell(2).ToString().Trim())) continue;
|
||
|
||
dataRow = dataTable.NewRow();
|
||
//for (int j = row.FirstCellNum; j < cellCount; ++j)
|
||
for (int j = row.FirstCellNum; j <= 6; ++j)
|
||
{
|
||
if (j == 0) {
|
||
dataRow[j] = sheet.SheetName;
|
||
continue;
|
||
}
|
||
cell = row.GetCell(j);
|
||
if (cell == null)
|
||
{
|
||
dataRow[j] = "";
|
||
}
|
||
else
|
||
{
|
||
//CellType(Unknown = -1,Numeric = 0,String = 1,Formula = 2,Blank = 3,Boolean = 4,Error = 5,)
|
||
switch (cell.CellType)
|
||
{
|
||
case CellType.Blank:
|
||
dataRow[j] = "";
|
||
break;
|
||
case CellType.Numeric:
|
||
short format = cell.CellStyle.DataFormat;
|
||
//對時間格式(2015.12.5、2015/12/5、2015-12-5等)的處理
|
||
if (format == 14 || format == 31 || format == 57 || format == 58)
|
||
dataRow[j] = cell.DateCellValue;
|
||
else
|
||
dataRow[j] = cell.NumericCellValue;
|
||
break;
|
||
case CellType.String:
|
||
//if (cell.StringCellValue == "C_B_B5F_GT_B51")
|
||
//{
|
||
// MessageBox.Show("C_B_B5F_GT_B51");
|
||
//}
|
||
dataRow[j] = cell.StringCellValue;
|
||
break;
|
||
}
|
||
|
||
}
|
||
}
|
||
dataTable.Rows.Add(dataRow);
|
||
}
|
||
#endregion
|
||
}
|
||
else continue;
|
||
}//if (firstRow.Cells.Count >=3 )
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
return dataTable;
|
||
}
|
||
catch (Exception e)
|
||
{
|
||
int i = dataTable.Rows.Count;
|
||
msge = e.Message;
|
||
if (fs != null)
|
||
{
|
||
fs.Close();
|
||
}
|
||
return null;
|
||
}
|
||
}
|
||
|
||
|
||
|
||
/// <summary>
|
||
/// 定義待驗證的Excel標題
|
||
/// </summary>
|
||
/// <returns></returns>
|
||
private static string[] GetStringNum()
|
||
{
|
||
string[] ExcelHeadList = new string[15] { "欄位1", "欄位2", "欄位3", "欄位4", "欄位5", "欄位6", "欄位7", "欄位8", "欄位9", "欄位10", "欄位11", "欄位12", "欄位13", "欄位14", "欄位15" };
|
||
return ExcelHeadList;
|
||
}
|
||
|
||
|
||
#region 匯出 Excel 模板
|
||
/// <summary>
|
||
/// 匯出 Excel模板
|
||
/// </summary>
|
||
public static void ExportExampleToExcel()
|
||
{
|
||
DataTable TableName = new DataTable();
|
||
TableName.Columns.Add("欄位1", typeof(string));
|
||
TableName.Columns.Add("欄位2", typeof(string));
|
||
TableName.Columns.Add("欄位3", typeof(string));
|
||
TableName.Columns.Add("欄位4", typeof(string));
|
||
TableName.Columns.Add("欄位5", typeof(string));
|
||
TableName.Columns.Add("欄位6", typeof(string));
|
||
TableName.Columns.Add("欄位7", typeof(string));
|
||
TableName.Columns.Add("欄位8", typeof(string));
|
||
TableName.Columns.Add("欄位9", typeof(string));
|
||
TableName.Columns.Add("欄位10", typeof(string));
|
||
TableName.Columns.Add("欄位12", typeof(string));
|
||
TableName.Columns.Add("欄位13", typeof(string));
|
||
TableName.Columns.Add("欄位14", typeof(string));
|
||
TableName.Columns.Add("欄位15", typeof(string));
|
||
TableName.Columns.Add("欄位16", typeof(string));
|
||
|
||
string FileName = "模板資訊匯入Excel模板";
|
||
SaveFileDialog saveFileDialog = new SaveFileDialog();
|
||
//設定檔案標題
|
||
saveFileDialog.Title = "匯出Excel檔案";
|
||
//設定檔案型別
|
||
saveFileDialog.Filter = "Excel 工作簿(*.xlsx)|*.xlsx|Excel 97-2003 工作簿(*.xls)|*.xls";
|
||
//設定預設檔案型別顯示順序
|
||
saveFileDialog.FilterIndex = 1;
|
||
//是否自動在檔名中新增副檔名
|
||
saveFileDialog.AddExtension = true;
|
||
//是否記憶上次開啟的目錄
|
||
saveFileDialog.RestoreDirectory = true;
|
||
//設定預設檔名
|
||
saveFileDialog.FileName = FileName;
|
||
//按下確定選擇的按鈕
|
||
if (saveFileDialog.ShowDialog() == DialogResult.OK)
|
||
{
|
||
//獲得檔案路徑
|
||
string localFilePath = saveFileDialog.FileName.ToString();
|
||
|
||
//資料初始化
|
||
int TotalCount; //總行數
|
||
int RowRead = 0; //已讀行數
|
||
int Percent = 0; //百分比
|
||
|
||
TotalCount = 15;
|
||
|
||
//NPOI
|
||
IWorkbook workbook;
|
||
string FileExt = Path.GetExtension(localFilePath).ToLower();
|
||
if (FileExt == ".xlsx")
|
||
{
|
||
workbook = new XSSFWorkbook();
|
||
}
|
||
else if (FileExt == ".xls")
|
||
{
|
||
workbook = new HSSFWorkbook();
|
||
}
|
||
else
|
||
{
|
||
workbook = null;
|
||
}
|
||
if (workbook == null)
|
||
{
|
||
return;
|
||
}
|
||
ISheet sheet = string.IsNullOrEmpty(FileName) ? workbook.CreateSheet("Sheet1") : workbook.CreateSheet(FileName);
|
||
|
||
|
||
//秒鐘
|
||
Stopwatch timer = new Stopwatch();
|
||
timer.Start();
|
||
|
||
try
|
||
{
|
||
//讀取標題
|
||
IRow rowHeader = sheet.CreateRow(0);
|
||
for (int i = 0; i < TableName.Columns.Count; i++)
|
||
{
|
||
ICell cell = rowHeader.CreateCell(i);
|
||
cell.SetCellValue(TableName.Columns[i].ColumnName);
|
||
}
|
||
|
||
Application.DoEvents();
|
||
|
||
//轉為位元組陣列
|
||
MemoryStream stream = new MemoryStream();
|
||
workbook.Write(stream);
|
||
var buf = stream.ToArray();
|
||
|
||
//儲存為Excel檔案
|
||
using (FileStream fs = new FileStream(localFilePath, FileMode.Create, FileAccess.Write))
|
||
{
|
||
fs.Write(buf, 0, buf.Length);
|
||
fs.Flush();
|
||
fs.Close();
|
||
}
|
||
Application.DoEvents();
|
||
|
||
//關閉秒鐘
|
||
timer.Reset();
|
||
timer.Stop();
|
||
|
||
//成功提示
|
||
if (MessageBox.Show("匯出成功,是否立即開啟?", "提示", MessageBoxButtons.YesNo, MessageBoxIcon.Information) == DialogResult.Yes)
|
||
{
|
||
System.Diagnostics.Process.Start(localFilePath);
|
||
}
|
||
|
||
}
|
||
catch (Exception ex)
|
||
{
|
||
MessageBox.Show(ex.Message, "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
|
||
}
|
||
finally
|
||
{
|
||
//關閉秒鐘
|
||
timer.Reset();
|
||
timer.Stop();
|
||
}
|
||
}
|
||
}
|
||
#endregion
|
||
|
||
#region 匯出 Excel
|
||
/// <summary>
|
||
/// 匯出Excel
|
||
/// </summary>
|
||
/// <param name="TableName"></param>
|
||
public static void ExportDataToExcel(DataTable TableName)
|
||
{
|
||
string FileName = DateTime.Now.GetHashCode().ToString();
|
||
SaveFileDialog saveFileDialog = new SaveFileDialog();
|
||
//設定檔案標題
|
||
saveFileDialog.Title = "匯出Excel檔案";
|
||
//設定檔案型別
|
||
saveFileDialog.Filter = "Excel 工作簿(*.xlsx)|*.xlsx|Excel 97-2003 工作簿(*.xls)|*.xls";
|
||
//設定預設檔案型別顯示順序
|
||
saveFileDialog.FilterIndex = 1;
|
||
//是否自動在檔名中新增副檔名
|
||
saveFileDialog.AddExtension = true;
|
||
//是否記憶上次開啟的目錄
|
||
saveFileDialog.RestoreDirectory = true;
|
||
//設定預設檔名
|
||
saveFileDialog.FileName = FileName;
|
||
//按下確定選擇的按鈕
|
||
if (saveFileDialog.ShowDialog() == DialogResult.OK)
|
||
{
|
||
//獲得檔案路徑
|
||
string localFilePath = saveFileDialog.FileName.ToString();
|
||
|
||
//資料初始化
|
||
int TotalCount; //總行數
|
||
int RowRead = 0; //已讀行數
|
||
int Percent = 0; //百分比
|
||
|
||
TotalCount = TableName.Rows.Count;
|
||
|
||
//NPOI
|
||
IWorkbook workbook;
|
||
string FileExt = Path.GetExtension(localFilePath).ToLower();
|
||
if (FileExt == ".xlsx")
|
||
{
|
||
workbook = new XSSFWorkbook();
|
||
}
|
||
else if (FileExt == ".xls")
|
||
{
|
||
workbook = new HSSFWorkbook();
|
||
}
|
||
else
|
||
{
|
||
workbook = null;
|
||
}
|
||
if (workbook == null)
|
||
{
|
||
return;
|
||
}
|
||
ISheet sheet = string.IsNullOrEmpty(FileName) ? workbook.CreateSheet("Sheet1") : workbook.CreateSheet(FileName);
|
||
|
||
|
||
//秒鐘
|
||
Stopwatch timer = new Stopwatch();
|
||
timer.Start();
|
||
|
||
try
|
||
{
|
||
//讀取標題
|
||
IRow rowHeader = sheet.CreateRow(0);
|
||
for (int i = 0; i < TableName.Columns.Count; i++)
|
||
{
|
||
ICell cell = rowHeader.CreateCell(i);
|
||
cell.SetCellValue(TableName.Columns[i].ColumnName);
|
||
}
|
||
|
||
//讀取資料
|
||
for (int i = 0; i < TableName.Rows.Count; i++)
|
||
{
|
||
IRow rowData = sheet.CreateRow(i + 1);
|
||
for (int j = 0; j < TableName.Columns.Count; j++)
|
||
{
|
||
ICell cell = rowData.CreateCell(j);
|
||
cell.SetCellValue(TableName.Rows[i][j].ToString());
|
||
}
|
||
//狀態列顯示
|
||
RowRead++;
|
||
Percent = (int)(100 * RowRead / TotalCount);
|
||
Application.DoEvents();
|
||
}
|
||
|
||
Application.DoEvents();
|
||
|
||
//轉為位元組陣列
|
||
MemoryStream stream = new MemoryStream();
|
||
workbook.Write(stream);
|
||
var buf = stream.ToArray();
|
||
|
||
//儲存為Excel檔案
|
||
using (FileStream fs = new FileStream(localFilePath, FileMode.Create, FileAccess.Write))
|
||
{
|
||
fs.Write(buf, 0, buf.Length);
|
||
fs.Flush();
|
||
fs.Close();
|
||
}
|
||
Application.DoEvents();
|
||
|
||
//關閉秒鐘
|
||
timer.Reset();
|
||
timer.Stop();
|
||
|
||
//成功提示
|
||
if (MessageBox.Show("匯出成功,是否立即開啟?", "提示", MessageBoxButtons.YesNo, MessageBoxIcon.Information) == DialogResult.Yes)
|
||
{
|
||
System.Diagnostics.Process.Start(localFilePath);
|
||
}
|
||
|
||
}
|
||
catch (Exception ex)
|
||
{
|
||
throw ex;
|
||
//MessageBox.Show(ex.Message, "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
|
||
}
|
||
finally
|
||
{
|
||
//關閉秒鐘
|
||
timer.Reset();
|
||
timer.Stop();
|
||
}
|
||
}
|
||
}
|
||
#endregion
|
||
}
|
||
}
|