.NET操作Excel

简介:

一.读取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,如需转载请自行联系原作者






相关文章
|
8月前
|
Java BI 数据处理
如何在Java中实现Excel操作
如何在Java中实现Excel操作
|
9月前
|
Java 数据库 数据安全/隐私保护
Java操作Excel文件导入导出【内含有 jxl.jar 】
Java操作Excel文件导入导出【内含有 jxl.jar 】
105 0
|
7月前
|
开发框架 .NET API
分享一个 ASP.NET Web Api 上传和读取 Excel的方案
分享一个 ASP.NET Web Api 上传和读取 Excel的方案
179 0
|
8月前
|
存储 对象存储 Python
`openpyxl`是一个用于读写Excel 2010 xlsx/xlsm/xltx/xltm文件的Python库。它不需要Microsoft Excel,也不需要.NET或COM组件。
`openpyxl`是一个用于读写Excel 2010 xlsx/xlsm/xltx/xltm文件的Python库。它不需要Microsoft Excel,也不需要.NET或COM组件。
Excel如何使用VBA操作引用其它工作簿中的单元格
Excel引用其它工作簿中的单元格的值及使用VBA操作
|
9月前
|
Python
【干货】python xlwt写入excel操作
【干货】python xlwt写入excel操作
|
9月前
|
图形学
【unity小技巧】unity读excel配置表操作,excel转txt文本,并读取txt文本内容,实例说明
【unity小技巧】unity读excel配置表操作,excel转txt文本,并读取txt文本内容,实例说明
327 0
|
9月前
|
分布式计算 大数据 数据处理
MaxCompute操作报错合集之在本地用tunnel命令上传excel表格到mc遇到报错: tunnel upload C:\Users***\Desktop\a.xlsx mc里的非分区表名 -s false;该怎么办
MaxCompute是阿里云提供的大规模离线数据处理服务,用于大数据分析、挖掘和报表生成等场景。在使用MaxCompute进行数据处理时,可能会遇到各种操作报错。以下是一些常见的MaxCompute操作报错及其可能的原因与解决措施的合集。
100 0
|
10月前
|
数据挖掘 数据库连接 数据处理
精通Excel意味着熟练掌握基础及进阶操作
精通Excel意味着熟练掌握基础及进阶操作,如数据透视表、VBA编程和自定义公式。提升效率的技巧包括善用快捷键、自动化重复任务、巧用公式与函数(如SUM和VLOOKUP)、利用数据透视表分析数据、设置条件格式、建立数据库连接、编写自定义函数、创建数据图表、使用模板和进行分组汇总。这些方法能有效提升数据分析和处理能力,优化工作效率。
219 2
|
10月前
|
Java Apache 索引
POI操作大全(动态合并单元格,为单元格生成一个自定义的数据显示格式,自定义公式计算结果生成,读取excel,word文件在生成图片,word指定位置生成图片)
POI操作大全(动态合并单元格,为单元格生成一个自定义的数据显示格式,自定义公式计算结果生成,读取excel,word文件在生成图片,word指定位置生成图片)
1161 0

热门文章

最新文章