博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
EXCLE 导入 或 导出
阅读量:4688 次
发布时间:2019-06-09

本文共 2311 字,大约阅读时间需要 7 分钟。

首先要引用 NPOI.dll   (可在网上下载!)

//导入
public void OnSubmit()
        {
            string path = Server.MapPath("/upload/201410/27/201410271103461051.xls");
            FileStream fs = File.Open(path, FileMode.Open);
            System.Data.DataTable dt = ConvertToDataTable(fs);
            
            foreach (DataRow row in dt.Rows)
            {
                if (row["Mobile1"] != null)
                {
                    Response.Write(row["Mobile1"].ToString() + " " + row["Mobile2"].ToString() + "
");
                }
            }
            Response.End();
        }
//excel转DataTable
public static DataTable ConvertToDataTable(System.IO.Stream excelFileStream)
        {
            HSSFWorkbook HSSFWorkbook = new HSSFWorkbook(excelFileStream);
            DataTable dt = new DataTable();
            HSSFSheet sheet = (HSSFSheet)HSSFWorkbook.GetSheetAt(0);
            System.Collections.IEnumerator rows = sheet.GetRowEnumerator();
            int n = 0;
            while (rows.MoveNext())
            {
                HSSFRow row = (HSSFRow)rows.Current;
                if (n == 0)
                {
                    for (int i = 0; i < row.LastCellNum; i++)
                    {
                        HSSFCell cell = (HSSFCell)row.GetCell(i);
                        if (cell == null)
                            continue;
                        DataColumn column = new DataColumn(cell.StringCellValue);
                        dt.Columns.Add(column);
                    }
                }
                else
                {
                    DataRow dtRow = dt.NewRow();
                    string rValue = "";
                    for (int i = 0, j = 0; i < row.LastCellNum; i++)
                    {
                        HSSFCell cell = (HSSFCell)row.GetCell(i);
                        if (cell == null)
                        {
                            dtRow[i] = "";
                        }
                        else
                        {
                            dtRow[j] = cell.ToString();
                            rValue = cell.ToString();
                            j++;
                        }
                    }
                    if (string.IsNullOrEmpty(rValue.Trim()))
                        break;
                    dt.Rows.Add(dtRow);
                }
                n++;
            }
            return dt;
        }
 
//导出
///
        /// 将明细表导出到Excel
        ///
        ///
要导入到Excel中的中文表头的Sql,将需要的字段通过sql as成中文名
///
/// 1 成功 -1失败
protected int ExportToExcel(string sql, HttpResponse response)
{
DataTable dt = CommOtherBLL.ExportToExcel(sql); //要导出的表
if (dt != null && dt.Rows.Count > 0)
{
StringBuilder strContent = new StringBuilder();
for (int i = 0; i < dt.Columns.Count; i++)
strContent.Append(dt.Columns[i] + "\t");
strContent.Append("\n");
for (int i = 0; i < dt.Rows.Count; i++)
{
for (int y = 0; y < dt.Columns.Count; y++)
strContent.Append(dt.Rows[i][y] + "\t");
strContent.Append("\n");
}
response.AddHeader("Content-Disposition", "attachment; filename=" + System.Web.HttpUtility.UrlEncode("excel", System.Text.Encoding.UTF8) + ".xls");
response.ContentType = "application/ms-excel";
response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
response.Write(strContent.ToString());
response.End();
return 1;
}
else
return -1;
}

转载于:https://www.cnblogs.com/xiaosa-blog/p/4318832.html

你可能感兴趣的文章
洛谷 P1101 单词方阵
查看>>
Swift DispatchQueue
查看>>
C#和JAVA 访问修饰符
查看>>
集合框架
查看>>
小甲鱼OD学习第1讲
查看>>
【转】简述生成式对抗网络
查看>>
HDU-1085 Holding Bin-Laden Captive-母函数
查看>>
php提示undefined index的几种解决方法
查看>>
轻量级原生 ajax 函数,支持 get/array post/array post/json
查看>>
LRJ
查看>>
Struts2环境搭建
查看>>
Linux: Check version info
查看>>
Javascript-正则表达式-开发中的使用.
查看>>
stl学习之测试stlen,cout等的运行速度
查看>>
入门GoldenGate总结
查看>>
魔戒三曲,黑暗散去;人皇加冕,光明归来
查看>>
Error和Exception
查看>>
Python和Singleton (单件)模式[转载]
查看>>
hibernate多对多单向(双向)关系映射
查看>>
二分查找题
查看>>