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
{
///
/// 將excel匯入到datatable
///
/// 存放資料庫取出的編號list
/// 返回結果
/// 返回datatable
public static DataTable ExcelToDataTable(List nosqllist, out string msge, out string filename)
{
bool isColumnName = true;//第一行是否是列名
msge = "0";
string filePath = "";//excel路徑
List NoList = new List();//儲存編號,防止重複
//開啟檔案對話方塊選擇檔案
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;
}
}
///
/// 定義待驗證的Excel標題
///
///
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 模板
///
/// 匯出 Excel模板
///
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
///
/// 匯出Excel
///
///
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
}
}