博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
.NET操作Excel
阅读量:6095 次
发布时间:2019-06-20

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

一.读取Excel数据,并显示

1.配置文件

<configuration>

    <system.web>
        <compilation debug="true" targetFramework="4.0" />
    </system.web>
  <appSettings>
    <!--连接03版本的-->
    <!--<add key="SQLCONNECTIONSTRING" value="Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=Excel 8.0;Data Source="/>
    <add key="DBPATH" value="App_Data\username.xls"/>-->
    
    <!--连接07版本的-->
    <add key="SQLCONNECTIONSTRING" value="Provider=Microsoft.ACE.OLEDB.12.0;Extended Properties=Excel 12.0 Xml;Data Source=" />
    <add key="DBPATH" value="App_Data\usernames.xlsx"/>
    <!--连接07access数据库-->
    <add key="OLEDBCONNECTIONSTRING" value="Provider=Microsoft.ACE.OLEDB.12.0;Extended Properties=Access 12.0 Xml;Data Source=" />
    <!--<add key="DBPATH" value="App_Data\username.accdb"/>-->
    <!--使用.net生成Excel表格-->
    <add key="SQLCONNECTIONSTR" value="data source=.;uid=sa;pwd=123456;database=students;pooling=true"/>
  </appSettings>
</configuration>

2.

using System;

using System.Configuration;
using System.Data;
using System.Data.OleDb;

namespace WebApplication

{
    public partial class MyExcelToDG : System.Web.UI.Page
    {
        private readonly string SQLCONNECTIONSTRING = ConfigurationManager.AppSettings["SQLCONNECTIONSTRING"].ToString();
        private readonly string DBPATH = ConfigurationManager.AppSettings["DBPATH"].ToString();
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                GridView1.DataSource = CreateDataSource();
                GridView1.DataBind();
            }
        }

        private DataSet CreateDataSource()

        {
            //设置Excel的文件访问地址
            String ExcelDBPath = SQLCONNECTIONSTRING + Server.MapPath(DBPATH) + ";";
            //定义访问Excel文件的连接
            OleDbConnection conn = new OleDbConnection(ExcelDBPath);
            //OleDbDataAdapter da = new OleDbDataAdapter("SELECT * FROM[username$]",conn);
            OleDbDataAdapter da = new OleDbDataAdapter("SELECT * FROM students", conn);
            DataSet ds = new DataSet();
            da.Fill(ds);
            return ds;
        }
    }
}

 

 

 

 

二.将sqlserver中的数据导出到Excel中

using System;

using System.Configuration;
using System.Data;
using System.Data.SqlClient;

namespace WebApplication

{
    public partial class MyDataToExcel : System.Web.UI.Page
    {
        private readonly string SQLCONNECTIONSTR = ConfigurationManager.AppSettings["SQLCONNECTIONSTR"].ToString();
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                //创建Excel文件

                try

                {
                    CreateExcelTable();
                    Response.Write("<script>alert('成功导出!')</script>");
                }
                catch (Exception)
                {
                    Response.Write("<script>alert('发生错误!')</script>");
                }
            }
        }
        //获取数据
        private DataSet GetData()
        {
            //从数据库中获取数据
            String cmdText = "Select * from Student_Info";
            using (SqlConnection conn = new SqlConnection(SQLCONNECTIONSTR))
            {
                SqlDataAdapter da = new SqlDataAdapter(cmdText, conn);
                conn.Open();
                DataSet ds = new DataSet();
                da.Fill(ds);
                return (ds);
            }
        }

        //创建Excel文件

        private void CreateExcelTable()
        {
            //从数据库获取数据
            DataSet ds = GetData();
            //创建Excel对象
            Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();
            //设置行和列的索引
            int rowIndex = 1;
            int collndex = 0;
            //添加Excel对象的WorkBooks
            excel.Application.Workbooks.Add(true);
            System.Data.DataTable table = ds.Tables[0];
            //将所得到的表的列名,赋给单元格
            foreach (DataColumn col in table.Columns)
            {
                //添加列名
                collndex++;
                excel.Cells[1, collndex] = col.ColumnName;
            }
            //同样的方法处理数据
            foreach(DataRow row in table.Rows)
            {
                rowIndex++;
                collndex = 0;
                foreach (DataColumn col in table.Columns)
                {
                    collndex++;
                    excel.Cells[rowIndex, collndex] = row[col.ColumnName].ToString();
                }
            }
            //不可见,即后台处理
            excel.Visible = false;
            excel.DisplayAlerts = false;
            //保存刚才创建的Excel表格
            excel.Save(MapPath("App_Data/ExcelTable.xls"));
            excel.Application.Workbooks.Close();
            excel.Application.Quit();
            excel.Quit();
            //释放使用的Excel对象
            System.Runtime.InteropServices.Marshal.ReleaseComObject(excel);
            GC.Collect();
        } 
    }
}

本文转自蓬莱仙羽51CTO博客,原文链接:http://blog.51cto.com/dingxiaowei/1366631,如需转载请自行联系原作者

你可能感兴趣的文章
SQL Server表分区详解
查看>>
使用FMDB最新v2.3版本教程
查看>>
SSIS从理论到实战,再到应用(3)----SSIS包的变量,约束,常用容器
查看>>
STM32启动过程--启动文件--分析
查看>>
垂死挣扎还是涅槃重生 -- Delphi XE5 公布会归来感想
查看>>
淘宝的几个架构图
查看>>
Android扩展 - 拍照篇(Camera)
查看>>
JAVA数组的定义及用法
查看>>
充分利用HTML标签元素 – 简单的xtyle前端框架
查看>>
设计模式(十一):FACADE外观模式 -- 结构型模式
查看>>
iOS xcodebuile 自动编译打包ipa
查看>>
程序员眼中的 SQL Server-执行计划教会我如何创建索引?
查看>>
【BZOJ】1624: [Usaco2008 Open] Clear And Present Danger 寻宝之路(floyd)
查看>>
cmake总结
查看>>
数据加密插件
查看>>
linux后台运行程序
查看>>
win7 vs2012/2013 编译boost 1.55
查看>>
IIS7如何显示详细错误信息
查看>>
ViewPager切换动画PageTransformer使用
查看>>
coco2d-x 基于视口的地图设计
查看>>