• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            直接通過ODBC讀寫Excel表格文件

            譯者:徐景周(原作:Alexander Mikula)

            下載本文示例代碼

            想要通過ODBC直接讀、寫Excel表格文件,首先,應確保ODBC中已安裝有Excel表格文件的驅動"MICROSOFT EXCEL DRIVER (*.XLS)"。然后,可根據下面步驟進行:

            1. 在StdAfx.h文件中加入

            #include <afxdb.h>
            #include <odbcinst.h>
            
            2. 通過ODBC直接創建Excel文件并在表中插入數據(暫定文件名:Demo.xls)
            //創建并寫入Excel文件
            void CRWExcel::WriteToExcel()
            {
            CDatabase database;
            CString sDriver = "MICROSOFT EXCEL DRIVER (*.XLS)"; // Excel安裝驅動
            CString sExcelFile = "c:\\demo.xls";                // 要建立的Excel文件
            CString sSql;
            TRY
            {
            // 創建進行存取的字符串
            sSql.Format("DRIVER={%s};DSN='''';FIRSTROWHASNAMES=1;READONLY=FALSE;CREATE_DB=\"%s\";DBQ=%s",
            sDriver, sExcelFile, sExcelFile);
            // 創建數據庫 (既Excel表格文件)
            if( database.OpenEx(sSql,CDatabase::noOdbcDialog) )
            {
            // 創建表結構(姓名、年齡)
            sSql = "CREATE TABLE demo (Name TEXT,Age NUMBER)";
            database.ExecuteSQL(sSql);
            // 插入數值
            sSql = "INSERT INTO demo (Name,Age) VALUES (''徐景周'',26)";
            database.ExecuteSQL(sSql);
            sSql = "INSERT INTO demo (Name,Age) VALUES (''徐志慧'',22)";
            database.ExecuteSQL(sSql);
            sSql = "INSERT INTO demo (Name,Age) VALUES (''郭徽'',27)";
            database.ExecuteSQL(sSql);
            }
            // 關閉數據庫
            database.Close();
            }
            CATCH_ALL(e)
            {
            TRACE1("Excel驅動沒有安裝: %s",sDriver);
            }
            END_CATCH_ALL;
            }
            
            3. 通過ODBC直接讀取Excel文件(暫定文件名:Demo.xls)
            // 讀取Excel文件
            void CRWExcel::ReadFromExcel()
            {
            CDatabase database;
            CString sSql;
            CString sItem1, sItem2;
            CString sDriver;
            CString sDsn;
            CString sFile = "Demo.xls"; 			// 將被讀取的Excel文件名
            // 檢索是否安裝有Excel驅動 "Microsoft Excel Driver (*.xls)"
            sDriver = GetExcelDriver();
            if (sDriver.IsEmpty())
            {
            // 沒有發現Excel驅動
            AfxMessageBox("沒有安裝Excel驅動!");
            return;
            }
            // 創建進行存取的字符串
            sDsn.Format("ODBC;DRIVER={%s};DSN='''';DBQ=%s", sDriver, sFile);
            TRY
            {
            // 打開數據庫(既Excel文件)
            database.Open(NULL, false, false, sDsn);
            CRecordset recset(&database);
            // 設置讀取的查詢語句.
            sSql = "SELECT Name, Age "
            "FROM demo "
            "ORDER BY Name ";
            // 執行查詢語句
            recset.Open(CRecordset::forwardOnly, sSql, CRecordset::readOnly);
            // 獲取查詢結果
            while (!recset.IsEOF())
            {
            //讀取Excel內部數值
            recset.GetFieldValue("Name ", sItem1);
            recset.GetFieldValue("Age", sItem2);
            // 移到下一行
            recset.MoveNext();
            }
            // 關閉數據庫
            database.Close();
            }
            CATCH(CDBException, e)
            {
            // 數據庫操作產生異常時...
            AfxMessageBox("數據庫錯誤: " + e->m_strError);
            }
            END_CATCH;
            }
            
            4. 獲取ODBC中Excel驅動的函數
            CString CRWExcel::GetExcelDriver()
            {
            char szBuf[2001];
            WORD cbBufMax = 2000;
            WORD cbBufOut;
            char *pszBuf = szBuf;
            CString sDriver;
            // 獲取已安裝驅動的名稱(涵數在odbcinst.h里)
            if (!SQLGetInstalledDrivers(szBuf, cbBufMax, &cbBufOut))
            return "";
            // 檢索已安裝的驅動是否有Excel...
            do
            {
            if (strstr(pszBuf, "Excel") != 0)
            {
            //發現 !
            sDriver = CString(pszBuf);
            break;
            }
            pszBuf = strchr(pszBuf, ''\0'') + 1;
            }
            while (pszBuf[1] != ''\0'');
            return sDriver;
            }
            
            作者信息:
            姓名:徐景周(未來工作室 Future Studio)
            EMAIL:jingzhou_xu@163.net

            posted on 2009-05-22 09:22 wrh 閱讀(1275) 評論(0)  編輯 收藏 引用

            導航

            <2008年4月>
            303112345
            6789101112
            13141516171819
            20212223242526
            27282930123
            45678910

            統計

            常用鏈接

            留言簿(19)

            隨筆檔案

            文章檔案

            收藏夾

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国产美女亚洲精品久久久综合| 久久久久久国产精品无码超碰| 99久久精品九九亚洲精品| 久久综合九色综合欧美狠狠| 99久久99久久精品国产片| 亚洲国产精品狼友中文久久久| 久久久久se色偷偷亚洲精品av| 欧美va久久久噜噜噜久久| 天天久久狠狠色综合| 久久精品日日躁夜夜躁欧美| 国产韩国精品一区二区三区久久 | 久久精品亚洲男人的天堂| 国内精品人妻无码久久久影院导航| 国产成人久久精品激情| 亚洲精品99久久久久中文字幕| 精品久久久噜噜噜久久久| 香蕉久久AⅤ一区二区三区| 99久久精品国内| 亚洲欧美成人综合久久久| 一级女性全黄久久生活片免费 | 久久久久亚洲AV成人网人人网站| 久久er国产精品免费观看2| 国产成人精品综合久久久久| 国产激情久久久久影院老熟女免费| 亚洲国产精品无码久久98| 久久影视国产亚洲| 国内精品久久久久久中文字幕 | 99久久夜色精品国产网站| 高清免费久久午夜精品| 奇米影视7777久久精品| 久久精品国产亚洲欧美| 色欲综合久久中文字幕网| 一本一本久久a久久精品综合麻豆| 91精品国产色综久久| 久久99精品国产麻豆| 少妇人妻88久久中文字幕| 中文精品久久久久人妻不卡| 一级A毛片免费观看久久精品| 香蕉久久夜色精品国产2020| 色欲综合久久躁天天躁| 思思久久99热只有频精品66|