亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > .NET > 正文

ASP.NET讀取Excel中的數據轉存到數據庫中

2024-07-21 02:51:54
字體:
來源:轉載
供稿:網友

【問題描述】

近日需要做一些數據倉庫的內容,發現數據庫搭好了以后,所有的數據文件都是Excel存儲的。然而數據又是及其繁雜,所以在創建好了事實表和維度表以后,準備自己寫一個代碼將Excel中多維的數據導入到數據庫中。Excel表的部分數據如下圖所示

所以需要對數據進行處理,處理之后添加到數據庫中。

【準備工作】

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

(1)頁面上的代碼

<div>       <%-- 文件上傳控件  用于將要讀取的文件上傳 并通過此控件獲取文件的信息--%>      <asp:FileUpload ID="fileSelect" runat="server" />          <%-- 點擊此按鈕執行讀取方法--%>       <asp:Button ID="btnRead" runat="server" Text="ReadStart" /></div> ?。?)后臺處理代碼

 //聲明變量(屬性) string currFilePath = string.Empty; //待讀取文件的全路徑  string currFileExtension = string.Empty;  //文件的擴展名  //Page_Load事件 注冊按鈕單擊事件  PRotected void Page_Load(object sender,EventArgs e)  {       }  //按鈕單擊事件   //里面的3個方法將在下面給出 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>///上傳文件到臨時目錄中 ///</ummary>private void Upload(){HttpPostedFile file = this.fileSelect.PostedFile;string fileName = file.FileName;string tempPath = System.IO.Path.GetTempPath(); //獲取系統臨時文件路徑fileName = System.IO.Path.GetFileName(fileName); //獲取文件名(不帶路徑)this.currFileExtension = System.IO.Path.GetExtension(fileName); //獲取文件的擴展名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及以上版本 不能出現多余的空格 而且分號注意//string connstring = Provider=Microsoft.JET.OLEDB.4.0;Data Source=" + path + ";Extended Properties='Excel 8.0;HDR=NO;IMEX=1';"; //Office 07以下版本 因為本人用Office2010 所以沒有用到這個連接字符串 可根據自己的情況選擇 或者程序判斷要用哪一個連接字符串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(); //得到第一個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; //標記DataTable 是否已經生成了列StreamReader reader = new StreamReader(path,System.Text.Encoding.Default); //數據流while(!reader.EndOfStream){string meaage = reader.ReadLine();string[] splitResult = message.Split(new char[]{','},StringSplitOption.None); //讀取一行 以逗號分隔 存入數組DataRow row = dt.NewRow();for(int i = 0;i<splitResult.Length;i++){if(!isDtHasColumn) //如果還沒有生成列{dt.Columns.Add("column" + i,typeof(string));}row[i] = splitResult[i];}dt.Rows.Add(row); //添加行isDtHasColumn = true; //讀取第一行后 就標記已經存在列 再讀取以后的行時,就不再生成列}return dt;}【后續工作】

將Excel表存入到DataTable對象中,可以將讀取到的表格數據轉存到數據庫的事實表中。將所需要的時間、地域以及品種的ID值讀取以后,開始與Excel表中的數據一起存放到數據庫中。部分代碼如下所示

int i, j;            int region = 0;            //獲取作物ID值            cropnumber = int.Parse(CropID.Text.ToString());            //獲得更新數據庫類型            if (mianji.Checked == true)  //遇到播種面積時新增數據庫條目            {                for(i=2;i<40;i++)   //省份                {                    if (i == 3 || i == 9 || i == 13 || i == 21 || i == 28 || i == 34)  //跳過空白區域                        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++)  //時間                    {                        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);                    }                }            }【后記】

這樣寫一個程序讀取Excel中的數據,大大節省了時間。但是還有幾個未解決的問題:

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

(2)如果數據量巨大,需要的品種又多,這個代碼就會有很大缺陷。就要一個一個輸入品種ID,然后一個一個Excel表進行導入。浪費了人力也浪費了時間,所以這個代碼的改進點還是不少的。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
丝袜亚洲另类欧美重口| 国产精品扒开腿做爽爽爽视频| 日韩电影中文 亚洲精品乱码| 欧美精品做受xxx性少妇| 国产欧美日韩高清| 国产精品一区二区性色av| 国内久久久精品| 欧美中文字幕视频在线观看| 国产成人精品在线| 国产精品久久久久久久美男| 国产精品一区二区三区久久久| 51ⅴ精品国产91久久久久久| 性金发美女69hd大尺寸| 欧美极品在线视频| 日韩欧美aⅴ综合网站发布| 久久视频中文字幕| 欧美性videos高清精品| 久久不射热爱视频精品| 亚洲亚裔videos黑人hd| 国产精品视频免费在线观看| 亚洲天堂免费观看| 久久99久久亚洲国产| 亚洲18私人小影院| 亚洲精品国产欧美| 亚洲欧美一区二区三区在线| 欧美性感美女h网站在线观看免费| 亚洲欧美视频在线| 欧洲午夜精品久久久| 国产成+人+综合+亚洲欧洲| 国产精品中文久久久久久久| 欧美性一区二区三区| 国产在线观看一区二区三区| 亚洲欧洲日韩国产| 亚洲高清不卡av| 欧美一级淫片丝袜脚交| 国产91精品久久久久久久| 亚洲精品日韩在线| yw.139尤物在线精品视频| 国产日韩欧美视频| 国产精品天天狠天天看| 国产精品免费电影| 97人人模人人爽人人喊中文字| 亚洲大胆人体在线| www国产亚洲精品久久网站| 91丨九色丨国产在线| 热草久综合在线| www.久久久久久.com| 国产精品视频专区| 夜夜嗨av色综合久久久综合网| 68精品国产免费久久久久久婷婷| 91在线无精精品一区二区| 日韩美女主播视频| 亚洲精品中文字幕女同| 日韩精品在线免费| 亚洲国产欧美一区二区三区同亚洲| 欧美极品少妇xxxxⅹ免费视频| 久久综合伊人77777| 国产精品久久久久久久久久99| 91高清在线免费观看| 欧美电影在线观看完整版| 亚洲精品女av网站| 97在线看免费观看视频在线观看| 日韩av大片免费看| 97国产精品视频人人做人人爱| 精品久久在线播放| 欧美专区国产专区| 欧美电影第一页| 亚洲精品一区二区网址| 日韩av免费在线看| 91美女高潮出水| 欧美性精品220| 亚洲欧美中文在线视频| 色综合伊人色综合网| 国产精品久久久久久av福利软件| 欧美在线观看日本一区| 成人免费高清完整版在线观看| 亚洲a成v人在线观看| 欧美一区第一页| 国产69精品久久久久9| 91精品国产777在线观看| 国产精品久久久久久久久久99| 欧美尤物巨大精品爽| 最新69国产成人精品视频免费| 国产精品一区二区久久国产| 98精品国产高清在线xxxx天堂| 综合国产在线观看| 亚洲人在线观看| 国产69精品久久久| 亚洲毛茸茸少妇高潮呻吟| 欧美体内谢she精2性欧美| 日韩综合视频在线观看| 91久久国产综合久久91精品网站| 成人妇女免费播放久久久| 亚洲男女性事视频| 国产精品一区二区三| 成人美女免费网站视频| 91精品国产色综合久久不卡98| 亚洲男人的天堂在线| 97在线视频国产| 在线观看久久av| 欧美日韩xxxxx| 亚洲精品久久久久久久久久久久| 国产精品日韩欧美大师| 欧美成人免费全部观看天天性色| 成人午夜高潮视频| www.精品av.com| 国产在线拍偷自揄拍精品| 亚洲男人天堂古典| 亚洲图片在区色| 久久精品视频在线播放| 久久激情视频免费观看| 国产精品视频成人| 亚洲国产精品视频在线观看| 国产在线视频不卡| 久久久亚洲国产天美传媒修理工| 中日韩美女免费视频网址在线观看| 最新91在线视频| 欧美乱人伦中文字幕在线| 深夜福利亚洲导航| 欧美男插女视频| 日韩精品视频在线观看网址| 国产视频综合在线| 日韩天堂在线视频| 欧美激情在线观看视频| 97视频色精品| 亚洲第一区中文字幕| 91av在线国产| 亚洲欧美成人在线| 日韩精品久久久久久福利| 97视频在线观看网址| 欧美壮男野外gaytube| 日韩在线观看成人| 亚洲人成网站免费播放| 亚洲v日韩v综合v精品v| 久久久久成人网| 久久成人免费视频| 国产精品美腿一区在线看| 久久精品国产成人| 久久久999精品| 粉嫩av一区二区三区免费野| 欧美国产精品人人做人人爱| 中文字幕不卡在线视频极品| 91精品免费视频| 亚洲国产福利在线| 疯狂做受xxxx高潮欧美日本| 欧洲s码亚洲m码精品一区| 久久综合久中文字幕青草| 亚洲福利视频久久| 日韩欧美亚洲一二三区| 欧美另类极品videosbest最新版本| 国产精品视频区1| 国产在线999| 国产狼人综合免费视频| 亚洲一区亚洲二区亚洲三区| 国产欧美精品xxxx另类| 欧美激情视频在线免费观看 欧美视频免费一| 九九热精品视频国产| 久久99热精品| 亚洲aaaaaa| 亚洲综合一区二区不卡| 国产成人在线播放| 福利视频一区二区| 亚洲jizzjizz日本少妇| 91精品在线影院|