MyXLS案例

时间:2023-03-09 07:17:59
MyXLS案例
using System;
using System.Data;
using org.in2bits.MyXls;
namespace Maticsoft.Common
{
/// <summary>
/// 操作EXCEL导出数据报表的类
/// Copyright (C) Maticsoft
/// </summary>
public class DataToExcel
{
public DataToExcel()
{
} /// <summary>
/// 绑定数据库生成XLS报表
/// using org.in2bits.MyXls;
/// </summary>
/// <param name="ds">获取DataSet数据集</param>
/// <param name="xlsName">报表表名</param>
public void toExcel(DataTable table, string xlsName)
{
XlsDocument xls = new XlsDocument();
xls.FileName = xlsName + ".xls";
int rowIndex = ;
int colIndex = ;
Worksheet sheet = xls.Workbook.Worksheets.Add("Sheet1");
Cells cells = sheet.Cells;
foreach (DataColumn col in table.Columns)
{
colIndex++;
cells.Add(, colIndex, col.ColumnName);
} foreach (DataRow row in table.Rows)
{
rowIndex++;
colIndex = ;
foreach (DataColumn col in table.Columns)
{
colIndex++;
Cell cell;
if (col.DataType == Type.GetType("System.Int32"))
{
if (Str2Int(row[col.ColumnName].ToString()) != )
{
cell = cells.Add(rowIndex, colIndex, Str2Int(row[col.ColumnName].ToString()));
}
}
else if (col.DataType == Type.GetType("System.Decimal") || col.DataType == Type.GetType("System.Double"))
{
if (Str2Double(row[col.ColumnName].ToString()) != )
{
cell = cells.Add(rowIndex, colIndex, Str2Double(row[col.ColumnName].ToString()));
}
}
else
{
if (!row[col.ColumnName].ToString().Equals("1900-01-01"))
cell = cells.Add(rowIndex, colIndex, row[col.ColumnName].ToString());
}
}
}
xls.Send();
} public DataTable FromExcel(string filepath)
{
XlsDocument xls = new XlsDocument(filepath);
Worksheet sheet = xls.Workbook.Worksheets["Sheet1"];
DataTable dt = new DataTable();
DataColumn cl = new DataColumn();
cl = new DataColumn("ID", System.Type.GetType("System.String"));
dt.Columns.Add(cl);
cl = new DataColumn("EID", System.Type.GetType("System.String"));
dt.Columns.Add(cl);
cl = new DataColumn("DID", System.Type.GetType("System.String"));
dt.Columns.Add(cl);
cl = new DataColumn("Type", System.Type.GetType("System.String"));
dt.Columns.Add(cl);
cl = new DataColumn("Model", System.Type.GetType("System.String"));
dt.Columns.Add(cl);
cl = new DataColumn("Custodian", System.Type.GetType("System.String"));
dt.Columns.Add(cl);
cl = new DataColumn("StorageUnits", System.Type.GetType("System.String"));
dt.Columns.Add(cl);
cl = new DataColumn("Money", System.Type.GetType("System.String"));
dt.Columns.Add(cl);
cl = new DataColumn("Status", System.Type.GetType("System.String"));
dt.Columns.Add(cl);
cl = new DataColumn("BuyTime", System.Type.GetType("System.String"));
dt.Columns.Add(cl);
cl = new DataColumn("StorageSites", System.Type.GetType("System.String"));
dt.Columns.Add(cl);
cl = new DataColumn("FinancialNumbers", System.Type.GetType("System.String"));
dt.Columns.Add(cl);
cl = new DataColumn("Remark", System.Type.GetType("System.String"));
dt.Columns.Add(cl);
for (int i = ; i < sheet.Rows.Count; i++)
{
DataRow row = dt.NewRow();
row[] = sheet.Rows[ushort.Parse(i.ToString())].GetCell().Value;
row[] = sheet.Rows[ushort.Parse(i.ToString())].GetCell().Value;
row[] = sheet.Rows[ushort.Parse(i.ToString())].GetCell().Value;
row[] = sheet.Rows[ushort.Parse(i.ToString())].GetCell().Value;
row[] = sheet.Rows[ushort.Parse(i.ToString())].GetCell().Value;
row[] = sheet.Rows[ushort.Parse(i.ToString())].GetCell().Value;
row[] = sheet.Rows[ushort.Parse(i.ToString())].GetCell().Value;
row[] = sheet.Rows[ushort.Parse(i.ToString())].GetCell().Value;
row[] = sheet.Rows[ushort.Parse(i.ToString())].GetCell().Value;
row[] = sheet.Rows[ushort.Parse(i.ToString())].GetCell().Value;
row[] = sheet.Rows[ushort.Parse(i.ToString())].GetCell().Value;
row[] = sheet.Rows[ushort.Parse(i.ToString())].GetCell().Value;
row[] = sheet.Rows[ushort.Parse(i.ToString())].GetCell().Value;
dt.Rows.Add(row);
}
return dt;
} public double Str2Double(string str)
{
double num = ;
try
{
num = Convert.ToDouble(str);
}
catch
{ }
return num;
} public int Str2Int(string str)
{
int num = ;
try
{
num = Convert.ToInt32(str);
}
catch
{ }
return num;
}
}
}