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. ASP.NET学习路线图

    转自:http://www.cnblogs.com/huangmeimujin/archive/2011/08/08/2131242.html 如果你已经有较多的面向对象开发经验,跳过以下这两步: 第 ...

  2. Linux 新手常用命令

    ubuntu的root用户默认是禁止的,需要手动打开才行 事实上ubuntu下的所有操作都用不到root用户,由于sudo的合理使用,避免了root用户下误操作而产生的毁灭性问题 root账号启用方法 ...

  3. php 修改上传文件大小

    有些朋友要通过自己的网站后台,包括论坛,来上传一些文件,php一般为2m,或8m(以下我们按默认为2m),接下来就是来讲怎么修改上传文件大小的. 1.首先修改执行上传文件限制 一般的文件上传,除非文件 ...

  4. C++类实现AVL树

    二叉查找树是个好东西,他让查找,插入,删除,这些常用操作变得高效,但是,他是存在问题的,那就是,在坏的输入序列下,树会退化成链表,这就很尴尬了,于是为了避免这种情况的发生,我们需要一种数据结构,可以自 ...

  5. 一步一步制作yaffs/yaffs2根文件系统(七)---真挚地道歉以及纠正前边出现的错误!

    接上一节http://blog.csdn.net/mybelief321/article/details/10040939 说实话,我当时写这个系列的博文的时候,感觉对BusyBox算是有点了解,直到 ...

  6. IO(Input Output)流__字节流

    续: ------->>>>字节流 IntputStream  OutputStream 需求:想要操作图片数据,就需要用到字节流. 读写操作: FileOutputStrea ...

  7. A Practical Guide to Distributed Scrum - 分布式Scrum的实用指南 - 读书笔记

    最近读了这本IBM出的<A Practical Guide to Distributed Scrum>(分布式Scrum的实用指南),书中的章节结构比较清楚,是针对Scrum项目进行,一个 ...

  8. Java-struts2的问题 java.lang.NoClassDefFoundError: org/apache/commons/lang3/StringUtils

    缺commons-lang3-3.1.jar,添加之后就可以了

  9. sql执行计划解析案例(二)

    sql执行计划解析案例(二)   今天是2013-10-09,本来以前自己在专注oracle sga中buffer cache 以及shared pool知识点的研究.但是在研究cache buffe ...

  10. shell脚本实现检測回文字符串

    全部回文字的结构特征例如以下: 假设字符数是偶数,那么它在结构上表现为:一个字符序列连着还有一个字符同样但次序恰好相反的字符序列. 假设字符数为奇数,那么它在结构上表现为:一个字符序列连着还有一个字符 ...