導航:首頁 > 版本升級 > c生成excel文件

c生成excel文件

發布時間:2024-12-29 17:11:14

1. 怎樣通過ODBC直接讀、寫Excel表格文件

想要通過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;

2. 如何用C語言讀入和輸出excel里的數據

簡單的方法是通過ODBC來實現:
具體實現
一、 包含Excel文件操作類頭文件
#include "CSpreadSheet.h"
二、 新建Excel文件,並寫入默認數據
// 新建Excel文件名及路徑,TestSheet為內部表名
CSpreadSheet SS("c:\\Test.xls", "TestSheet");

CStringArray sampleArray, testRow;

SS.BeginTransaction();

// 加入標題
sampleArray.RemoveAll();
sampleArray.Add("姓名");
sampleArray.Add("年齡");
SS.AddHeaders(sampleArray);

// 加入數據
CString strName[] = {"徐景周","徐志慧","郭徽","牛英俊","朱小鵬"};
CString strAge[] = {"27","23","28","27","26"};
for(int i = 0; i < sizeof(strName)/sizeof(CString); i++)
{
sampleArray.RemoveAll();
sampleArray.Add(strName[i]);
sampleArray.Add(strAge[i]);
SS.AddRow(sampleArray);
}

SS.Commit();

三、 讀取Excel文件數據
CSpreadSheet SS("c:\\Test.xls", "TestSheet");

CStringArray Rows, Column;

//清空列表框
m_AccessList.ResetContent();
for (int i = 1; i <= SS.GetTotalRows(); i++)
{
// 讀取一行
SS.ReadRow(Rows, i);
CString strContents = "";
for (int j = 1; j <= Rows.GetSize(); j++)
{
if(j == 1)
strContents = Rows.GetAt(j-1);
else
strContents = strContents + " --> " + Rows.GetAt(j-1);
}

m_AccessList.AddString(strContents);
}

3. 怎麼把C語言中產生的數據導入到Excel表格

1、C語言產生ASCII數據文件,使用空格做作為數據分隔符。
2、進入Excel,選擇數據選項卡 / 獲取外部數據工具組 / 自文本按鈕
3、進入數據導入對話框,
在第一步中,選擇使用數據分隔符(不選固定數據長度)
在第二步中,指定數據分隔符為空格
4、按對話框向導操作就可以達到目的啦。

4. 求用winform導入導出excel的方法!!!另外我在調試時出錯!!!

在這里補充一下,如果你的電腦安裝了microso offices vs中的操作都好了還是出錯的話,你看看你的offices辦公軟體安裝在c盤,還是其他盤下。我當時遇到的問題是這樣,我的是安裝在d:盤了,結果換了c:盤就好了。

5. 怎麼把c語言里的數據 用到excel

//直接復制,即在可D盤新建一個Excel文件,
#include<stdio.h>
#include<stdlib.h>//包含 exit(0);函數,
int main()
{

char *p="名字\t年齡\n張三\t28\n李四\t30\n";
FILE *fp;
if((fp=fopen("d:\\test.xls","w"))==NULL)
{
printf("你無權寫入");
exit(0);//這個函數的意思是結束這個程序
}
else
{
fwrite(p,sizeof(char),strlen(p),fp);

}
fclose(fp); //關閉文件
printf("OK 執行完畢\n");
return 0;
}

6. 如何將c計算的結果存儲成一個excel文件

如果是標准C的話比較困難,

最簡單的方法就是將數據用逗號分隔,保存成.csv文件,

打開的時候會直接打開成excel文件

比如

1,2,3,4

5,6,7,8

保存成.csv文件,打開後如下圖所示

閱讀全文

與c生成excel文件相關的資料

熱點內容
vs如何向伺服器存取視頻文件 瀏覽:180
關於資料庫的翻譯好的外文文獻 瀏覽:494
win10設置圖標比例 瀏覽:149
linuxtar命令詳解 瀏覽:774
文件夾不見了怎麼找回 瀏覽:423
linux虛擬機的映像文件 瀏覽:88
android程序發布 瀏覽:878
電腦怎麼使用微信上的數據線 瀏覽:17
ga代碼是什麼 瀏覽:553
將文件導入word 瀏覽:214
如何通過ps把印章蓋到掃描文件上 瀏覽:600
招標文件和投遞有什麼區別 瀏覽:167
編程沒有基礎怎麼學java 瀏覽:968
怎麼再電腦上存文件 瀏覽:602
夢幻手游數據在哪個文件夾 瀏覽:851
刪除此電腦的3d對象文件夾 瀏覽:700
怎麼查看文件夾下有多少個文件 瀏覽:556
c編程怎麼發牌 瀏覽:25
留守兒童網站怎麼下載 瀏覽:851
vba編程如何一步一步測試代碼 瀏覽:810

友情鏈接