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;
}
}
}

MyXLS案例的更多相关文章

  1. 数据库优化案例——————某市中心医院HIS系统

    记得在自己学习数据库知识的时候特别喜欢看案例,因为优化的手段是容易掌握的,但是整体的优化思想是很难学会的.这也是为什么自己特别喜欢看案例,今天也开始分享自己做的优化案例. 最近一直很忙,博客产出也少的 ...

  2. SQL Server内存遭遇操作系统进程压榨案例

    场景: 最近一台DB服务器偶尔出现CPU报警,我的邮件报警阈(请读yù)值设置的是15%,开始时没当回事,以为是有什么统计类的查询,后来越来越频繁. 探索: 我决定来查一下,究竟是什么在作怪,我排查的 ...

  3. solr_架构案例【京东站内搜索】(附程序源代码)

    注意事项:首先要保证部署solr服务的Tomcat容器和检索solr服务中数据的Tomcat容器,它们的端口号不能发生冲突,否则web程序是不可能运行起来的. 一:solr服务的端口号.我这里的sol ...

  4. Yeoman 官网教学案例:使用 Yeoman 构建 WebApp

    STEP 1:设置开发环境 与yeoman的所有交互都是通过命令行.Mac系统使用terminal.app,Linux系统使用shell,windows系统可以使用cmder/PowerShell/c ...

  5. 了不起的 nodejs-TwitterWeb 案例 bug 解决

    了不起的nodejs算是一本不错的入门书,不过书中个别案例存在bug,按照书中源码无法做出和书中相同效果,原本兴奋的心情掺杂着些许失落. 现在我们看一下第七章HTTP,一个Twitter Web客户端 ...

  6. 一个表缺失索引发的CPU资源瓶颈案例

    背景 近几日,公司的应用团队反应业务系统突然变慢了,之前是一直比较正常.后与业务部门沟通了解详情,得知最近生意比较好,同时也在做大的促销活动,使得业务数据处理的量出现较大的增长,最终系统在处理时出现瓶 ...

  7. 【Machine Learning】决策树案例:基于python的商品购买能力预测系统

    决策树在商品购买能力预测案例中的算法实现 作者:白宁超 2016年12月24日22:05:42 摘要:随着机器学习和深度学习的热潮,各种图书层出不穷.然而多数是基础理论知识介绍,缺乏实现的深入理解.本 ...

  8. Redis简单案例(二) 网站最近的访问用户

    我们有时会在网站中看到最后的访问用户.最近的活跃用户等等诸如此类的一些信息.本文就以最后的访问用户为例, 用Redis来实现这个小功能.在这之前,我们可以先简单了解一下在oracle.sqlserve ...

  9. springmvc+bootstrap+jquerymobile完整搭建案例(提供下载地址)

    用一张简单的截图说明下,然后提供一个下载地址. bootstrap的大部分样式官方都是写好的,所以只需要class="官方样式即可",具体可以看官方的案例,下面来个地址 http: ...

随机推荐

  1. JVM Monitoring: JMX or SNMP?

    JVM Monitoring: JMX or SNMP? By daniel on Feb 23, 2007 Since JavaTM SE 5.0, the JRE provides a means ...

  2. usaco3.33Camelot(BFS)

    恶心的题啊 .. 先枚举哪个点是所有人集合的点 再枚举所有骑士遇见国王的点 如果全部枚举出来会大大的TLE 经大牛验证 只需要枚举国王周围的点就可以了+-2 之内 然后各种繁琐 各种错误 骑士有可能不 ...

  3. 转自 x_x的百度空间

    空华人生         by 淡漠的心情 昨天,又昨天. 今天,又今天. 明天,又明天. 日历渐渐稀薄,忽然发现,那是时间的痕迹. 似乎,总是在麻木的等待. 何时,才能历尽. 再算算,我又还有多少天 ...

  4. 【转】android获取屏幕宽度和高度

    原文网址:http://www.cnblogs.com/howlaa/p/4123186.html 1. WindowManager wm = (WindowManager) getContext() ...

  5. android学习之BUG——The connection to adb is down, and a severe error has occured.

    开始--运行--cmd 进入命令提示符 输入netstat -ano 即可看到所有连接的PID 之后在任务管理器中找到这个PID所对应的程序如果任务管理器中没有PID这一项,可以在任务管理器中选&qu ...

  6. WebTable 扩展

    # coding:utf-8 """ 页面 table处理 """ from selenium import webdriver from ...

  7. AppScan修复漏洞:启用不安全的HTTP方法

    最近对于系统使用Appscan扫描出中危漏洞“启用不安全的HTTP方法,找了很多修复方法都不能达到效果. 漏洞截图: 漏洞描述: 危险级别   中危险 影响页面   整个WEB页面. 简短描述   管 ...

  8. UART(串口)

    (1)串行通信线路三种工作方式:单工通信.半双工通信.全双工通信 单工:单工就是指A只能发信号,而B只能接收信号,通信是单向的. 半双工:半双工就是指A能发信号给B,B也能发信号给A,但这两个过程不能 ...

  9. 关于理解《C++ 对象模型》中:把单一元素的数组放在末尾,struct可以拥有可变大小的数组

    这一章在第19页,写的好深奥,我竟然没看明白在说什么--之后再看了几遍,终于明白了. 原文: C程序员的巧计有时候却成为c++程序员的陷阱.例如把单一元素的数组放在一个struct的末尾,于是每个st ...

  10. JavaScript高级程序设计37.pdf

    用DOM范围实现简单选择 selectNode()和selectNodeContents()它们都接收一个DOM节点参数,然后使用该节点中的信息来填充范围,其中selectNode()方法选择整个节点 ...