zoukankan      html  css  js  c++  java
  • 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 = 1;
                int colIndex = 0;
                Worksheet sheet = xls.Workbook.Worksheets.Add("Sheet1");
                Cells cells = sheet.Cells;
                foreach (DataColumn col in table.Columns)
                {
                    colIndex++;
                    cells.Add(1, colIndex, col.ColumnName);
                }
    
                foreach (DataRow row in table.Rows)
                {
                    rowIndex++;
                    colIndex = 0;
                    foreach (DataColumn col in table.Columns)
                    {
                        colIndex++;
                        Cell cell;
                        if (col.DataType == Type.GetType("System.Int32"))
                        {
                            if (Str2Int(row[col.ColumnName].ToString()) != 0)
                            {
                                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()) != 0)
                            {
                                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 = 2; i < sheet.Rows.Count; i++)
                {
                    DataRow row = dt.NewRow();
                    row[0] = sheet.Rows[ushort.Parse(i.ToString())].GetCell(1).Value;
                    row[1] = sheet.Rows[ushort.Parse(i.ToString())].GetCell(2).Value;
                    row[2] = sheet.Rows[ushort.Parse(i.ToString())].GetCell(3).Value;
                    row[3] = sheet.Rows[ushort.Parse(i.ToString())].GetCell(4).Value;
                    row[4] = sheet.Rows[ushort.Parse(i.ToString())].GetCell(5).Value;
                    row[5] = sheet.Rows[ushort.Parse(i.ToString())].GetCell(6).Value;
                    row[6] = sheet.Rows[ushort.Parse(i.ToString())].GetCell(7).Value;
                    row[7] = sheet.Rows[ushort.Parse(i.ToString())].GetCell(8).Value;
                    row[8] = sheet.Rows[ushort.Parse(i.ToString())].GetCell(9).Value;
                    row[9] = sheet.Rows[ushort.Parse(i.ToString())].GetCell(10).Value;
                    row[10] = sheet.Rows[ushort.Parse(i.ToString())].GetCell(11).Value;
                    row[11] = sheet.Rows[ushort.Parse(i.ToString())].GetCell(12).Value;
                    row[12] = sheet.Rows[ushort.Parse(i.ToString())].GetCell(13).Value;
                    dt.Rows.Add(row);
                }
                return dt;
            }
    
            public double Str2Double(string str)
            {
                double num = 0;
                try
                {
                    num = Convert.ToDouble(str);
                }
                catch
                { }
                return num;
            }
    
            public int Str2Int(string str)
            {
                int num = 0;
                try
                {
                    num = Convert.ToInt32(str);
                }
                catch
                { }
                return num;
            }
        }
    }
  • 相关阅读:
    【转】ASP.NET MVC 使用 FluentScheduler 定时器计划任务
    【转】prototype扩展的JavaScript常用函数库
    【转】JavaScript系列文章:自动类型转换
    【转】Open Live Writer 插件更新
    highcharts与highstock实例
    SQL SERVER数据类型与C#数据类型对照表
    Highcharts在IE中不能一次性正常显示的一种解决办法
    MIME类型大全
    几种工具反编译被编译好的DLL文件
    MySQL之数据库的操作
  • 原文地址:https://www.cnblogs.com/varorbc/p/4214710.html
Copyright © 2011-2022 走看看