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. HDU-2523 SORT AGAIN

    http://acm.hdu.edu.cn/showproblem.php?pid=2523 学习哈希和注意i++,后要--i: SORT AGAIN Time Limit: 2000/1000 MS ...

  2. web调试工具

    Fiddler是最强大最好用的Web调试工具之一,它能记录所有客户端和服务器的http和https请求,允许你监视,设置断点,甚至修改输入输出数据. 使用Fiddler无论对开发还是测试来说,都有很大 ...

  3. 将批量下载的博客导入到手机后,通过豆约翰博客阅读器APP(Android手机)进行浏览,白字黑底,保护眼睛,图文并茂。

    首先下面演示的博文来自于以下地址:http://www.douban.com/note/423939291/ 需要先通过博客备份专家将导出的博文导入到手机(还不会用的朋友请先阅读http://www. ...

  4. 删除顺序链表中重复的数 (一) leecode

    Given a sorted linked list, delete all duplicates such that each element appear only once. For examp ...

  5. Educational Codeforces Round 3

    A. USB Flash Drives 水题,排序即可 ]; int main() { int n,m; scanf("%d%d",&n,&m); ;i<n; ...

  6. yii中上传图片及文件

    Yii 提供了 CUploadedFile 来上传文件,比如图片,或者文档. 官方关于这个类的介绍 : http://www.yiichina.com/api/CUploadedFile CUploa ...

  7. UVA 6199 不定根最小树形图

    首先是最小树形图的介绍. 看这个博客.最小树形图 上面介绍的很详细了,我就讲一下这道题的题意. 首先给出一些二维点坐标,这些坐标之间构成一些有向图,根据题意,假设两个点a(x1 ,y1) ,b(x2 ...

  8. nginx定时备份access访问日志并重启nginx

    用.sh脚本写了备份日志脚本 其实就是转移文件改名后重新建一个空文件 mv /alidata/log/nginx/access/wxtest.log /alidata/log/nginx/access ...

  9. Linux的文件属性

    在Linux中,文件的拥有者可以将文件的属性设置成三种属性,可读(r).可写(w)和可执行(x).文件又分为三个不同的用户级别,文件的拥有者(u),文件的所属组(g),其他用户(o). 第一个字符显示 ...

  10. DevExpress GridControl 后台设置列

    /// <summary> /// 初始化GridView /// </summary> /// <param name="gv">GridVi ...