国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > .NET > 正文

ASP.NET讀取Excel中的數(shù)據(jù)轉(zhuǎn)存到數(shù)據(jù)庫(kù)中

2024-07-21 02:51:54
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

【問(wèn)題描述】

近日需要做一些數(shù)據(jù)倉(cāng)庫(kù)的內(nèi)容,發(fā)現(xiàn)數(shù)據(jù)庫(kù)搭好了以后,所有的數(shù)據(jù)文件都是Excel存儲(chǔ)的。然而數(shù)據(jù)又是及其繁雜,所以在創(chuàng)建好了事實(shí)表和維度表以后,準(zhǔn)備自己寫一個(gè)代碼將Excel中多維的數(shù)據(jù)導(dǎo)入到數(shù)據(jù)庫(kù)中。Excel表的部分?jǐn)?shù)據(jù)如下圖所示

所以需要對(duì)數(shù)據(jù)進(jìn)行處理,處理之后添加到數(shù)據(jù)庫(kù)中。

【準(zhǔn)備工作】

首先需要找到從Excel讀取數(shù)據(jù)的代碼。參考網(wǎng)址:http://www.jb51.net/article/34096.htm。代碼如下:

(1)頁(yè)面上的代碼

<div>       <%-- 文件上傳控件  用于將要讀取的文件上傳 并通過(guò)此控件獲取文件的信息--%>      <asp:FileUpload ID="fileSelect" runat="server" />          <%-- 點(diǎn)擊此按鈕執(zhí)行讀取方法--%>       <asp:Button ID="btnRead" runat="server" Text="ReadStart" /></div>  (2)后臺(tái)處理代碼

 //聲明變量(屬性) string currFilePath = string.Empty; //待讀取文件的全路徑  string currFileExtension = string.Empty;  //文件的擴(kuò)展名  //Page_Load事件 注冊(cè)按鈕單擊事件  PRotected void Page_Load(object sender,EventArgs e)  {       }  //按鈕單擊事件   //里面的3個(gè)方法將在下面給出 protected void btnRead_Click(object sender,EventArgs e) {     Upload();  //上傳文件方法     if(this.currFileExtension ==".xlsx" || this.currFileExtension ==".xls")       {            DataTable dt = ReadExcelToTable(currFilePath);  //讀取Excel文件(.xls和.xlsx格式)       }       else if(this.currFileExtension == ".csv")         {               DataTable dt = ReadExcelWidthStream(currFilePath);  //讀取.csv格式文件         } }///<summary>///上傳文件到臨時(shí)目錄中 ///</ummary>private void Upload(){HttpPostedFile file = this.fileSelect.PostedFile;string fileName = file.FileName;string tempPath = System.IO.Path.GetTempPath(); //獲取系統(tǒng)臨時(shí)文件路徑fileName = System.IO.Path.GetFileName(fileName); //獲取文件名(不帶路徑)this.currFileExtension = System.IO.Path.GetExtension(fileName); //獲取文件的擴(kuò)展名this.currFilePath = tempPath + fileName; //獲取上傳后的文件路徑 記錄到前面聲明的全局變量file.SaveAs(this.currFilePath); //上傳}///<summary>///讀取xls/xlsx格式的Excel文件的方法 ///</ummary>///<param name="path">待讀取Excel的全路徑</param>///<returns></returns>private DataTable ReadExcelToTable(string path){//連接字符串string connstring = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + path + ";Extended Properties='Excel 8.0;HDR=NO;IMEX=1';"; // Office 07及以上版本 不能出現(xiàn)多余的空格 而且分號(hào)注意//string connstring = Provider=Microsoft.JET.OLEDB.4.0;Data Source=" + path + ";Extended Properties='Excel 8.0;HDR=NO;IMEX=1';"; //Office 07以下版本 因?yàn)楸救擞肙ffice2010 所以沒(méi)有用到這個(gè)連接字符串 可根據(jù)自己的情況選擇 或者程序判斷要用哪一個(gè)連接字符串using(OleDbConnection conn = new OleDbConnection(connstring)){conn.Open();DataTable sheetsName = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables,new object[]{null,null,null,"Table"}); //得到所有sheet的名字string firstSheetName = sheetsName.Rows[0][2].ToString(); //得到第一個(gè)sheet的名字string sql = string.Format("SELECT * FROM [{0}],firstSheetName); //查詢字符串OleDbDataAdapter ada =new OleDbDataAdapter(sql,connstring);DataSet set = new DataSet();ada.Fill(set);return set.Tables[0];}}///<summary>///讀取csv格式的Excel文件的方法 ///</ummary>///<param name="path">待讀取Excel的全路徑</param>///<returns></returns>private DataTable ReadExcelWithStream(string path){DataTable dt = new DataTable();bool isDtHasColumn = false; //標(biāo)記DataTable 是否已經(jīng)生成了列StreamReader reader = new StreamReader(path,System.Text.Encoding.Default); //數(shù)據(jù)流while(!reader.EndOfStream){string meaage = reader.ReadLine();string[] splitResult = message.Split(new char[]{','},StringSplitOption.None); //讀取一行 以逗號(hào)分隔 存入數(shù)組DataRow row = dt.NewRow();for(int i = 0;i<splitResult.Length;i++){if(!isDtHasColumn) //如果還沒(méi)有生成列{dt.Columns.Add("column" + i,typeof(string));}row[i] = splitResult[i];}dt.Rows.Add(row); //添加行isDtHasColumn = true; //讀取第一行后 就標(biāo)記已經(jīng)存在列 再讀取以后的行時(shí),就不再生成列}return dt;}【后續(xù)工作】

將Excel表存入到DataTable對(duì)象中,可以將讀取到的表格數(shù)據(jù)轉(zhuǎn)存到數(shù)據(jù)庫(kù)的事實(shí)表中。將所需要的時(shí)間、地域以及品種的ID值讀取以后,開(kāi)始與Excel表中的數(shù)據(jù)一起存放到數(shù)據(jù)庫(kù)中。部分代碼如下所示

int i, j;            int region = 0;            //獲取作物ID值            cropnumber = int.Parse(CropID.Text.ToString());            //獲得更新數(shù)據(jù)庫(kù)類型            if (mianji.Checked == true)  //遇到播種面積時(shí)新增數(shù)據(jù)庫(kù)條目            {                for(i=2;i<40;i++)   //省份                {                    if (i == 3 || i == 9 || i == 13 || i == 21 || i == 28 || i == 34)  //跳過(guò)空白區(qū)域                        continue;                    //讀取地域ID值                    string proname = exceldt.Rows[i][0].ToString().Replace(" ", "");                    string sqlstr = "select Region_ID from [DimRegion] where Province_Name='" + proname + "'";                    DataTable dt = new DataTable();                    dt = BaseClass1.ReadTable(sqlstr);                    region = int.Parse(dt.Rows[0][0].ToString());                    for(j=1;j<60;j++)  //時(shí)間                    {                        float area = float.Parse(exceldt.Rows[i][j].ToString());                        string str = "insert into[FactCropProducts](Time_ID,Region_ID,Croptype_ID,Area) values(" + j + "," + region + "," + cropnumber + "," + area + ")";                        BaseClass1.execsql(str);                    }                }            }【后記】

這樣寫一個(gè)程序讀取Excel中的數(shù)據(jù),大大節(jié)省了時(shí)間。但是還有幾個(gè)未解決的問(wèn)題:

(1)如果Excel表第一個(gè)sheet的名字為中文名,第二個(gè)sheet為Sheet1。則使用上面的代碼雖然是讀取第一個(gè)sheet的名稱,但是實(shí)際卻讀到的是Sheet1的內(nèi)容。

(2)如果數(shù)據(jù)量巨大,需要的品種又多,這個(gè)代碼就會(huì)有很大缺陷。就要一個(gè)一個(gè)輸入品種ID,然后一個(gè)一個(gè)Excel表進(jìn)行導(dǎo)入。浪費(fèi)了人力也浪費(fèi)了時(shí)間,所以這個(gè)代碼的改進(jìn)點(diǎn)還是不少的。


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 伊金霍洛旗| 枝江市| 二手房| 铜鼓县| 嫩江县| 柯坪县| 祁门县| 阿坝县| 奉新县| 腾冲县| 大悟县| 正定县| 米脂县| 丰县| 贺兰县| 上杭县| 喜德县| 吉安市| 辰溪县| 法库县| 扬州市| 枣强县| 杭锦旗| 济南市| 景德镇市| 寿阳县| 育儿| 恩施市| 长宁区| 云浮市| 合肥市| 绥芬河市| 彝良县| 澜沧| 浦北县| 静海县| 淮安市| 甘德县| 汉沽区| 称多县| 伊川县|