Asp.net(C#)中自动获取Excel的Sheet名

方法一:

Excel.Application myExcel = new Excel.Application();
object missing = System.Reflection.Missing.Value;
myExcel.Application.Workbooks.Open(this.txtFile.Text, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing, missing);  //this.txtFile.Text为Excel文件的全路径
Excel.Workbook myBook = myExcel.Workbooks[1];

//获取第一个Sheet
Excel.Worksheet sheet = (Excel.Worksheet)myBook.Sheets[1]; 
string sheetName = sheet.Name;  //Sheet名

 

//获取全部Sheet名

public static StringCollection ExcelSheetName(string filepath)
        {
            StringCollection names = new StringCollection();
            string strConn;
            strConn = "Provider=Microsoft.Ace.OLEDB.12.0;Data Source=" + filepath + ";Extended Properties='Excel 12.0;HDR=Yes;IMEX=2'";
            OleDbConnection conn = new OleDbConnection(strConn);
            conn.Open();
            DataTable sheetNames = conn.GetOleDbSchemaTable
            (System.Data.OleDb.OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" });
            conn.Close();

            foreach (DataRow dr in sheetNames.Rows)
            {
                names.Add(dr[2].ToString());
            }
            return names;
        }

 

备注:操作完后要关闭:

myBook.Close(Type.Missing,Type.Missing,Type.Missing);
 myExcel.Quit();

 

方法二

/// <summary>
/// 获取Excel全部Sheet名
/// </summary>
/// <param name="sFileName">路径</param>
/// <returns></returns>
 public string GetSheetNames(string sFileName)
{
         string sheetName = "";
         using (OleDbConnection oledbConn = new OleDbConnection())
         {
                try
                {
                    oledbConn.ConnectionString = "Provider=Microsoft.Jet.Oledb.4.0;data source=" + sFileName + ";Extended Properties=Excel 8.0;";

                    oledbConn.Open();

                    using (DataTable dtOledb = oledbConn.GetSchema("Tables"))
                    {
                        using (DataTableReader dtReader = new DataTableReader(dtOledb))
                        {
                            while (dtReader.Read())
                            {
                                //获取Sheet名
                                sheetName += dtReader["Table_Name"].ToString();
                            }
                        }
                    }
                }
                catch (Exception ex)
                {
                    throw ex;
                }
            }
            return sheetName;
        }

转载地址:   http://blog.sina.com.cn/s/blog_4a50d85b0100yotp.html
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值