Ⅰ (菜鸟提问)如何实现用C语言读写excel文档
牛~这个也算菜鸟问题啊?如果机器上装了Excel可以使用COM来实现你的想法如果机器上没装Excel建议你使用第三方库来完成你的想法
Ⅱ [c++]推荐一个可以读写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;}// 获取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;}
Ⅲ 如何用C语言来读取EXCEL文件中的数据
自己去读Excel文件我估计几乎是不可能的,可以借助Excel提供的数据库驱动程序以数据库的形式去访问,但用纯C语言穿靴戴帽的代码较多,用C++估计简便点,网上很容易搜到。
Ⅳ C语言读取excel文件的数据
简单的方法是通过ODBC来实现:具体实现一、 包含文件操作类头文件#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);elsestrContents = strContents + " –> " + Rows.GetAt(j-1);}m_AccessList.AddString(strContents);}
Ⅳ 怎样用C语言读取excel文件
C语言提供的文件读写功能一般都是打开文本文件或二进制文件,这是ANSI C的的规定。至于读取excel文件,我想可能是先将其转换成文本文件或二进制文件,然后再读取吧。
Ⅵ C语言如何操作excel文件
1.写操作 第一步:单纯C语言写入Excel文件只能是 *.csv的后缀文件(是和txt一样,以二进制文本形式存储,它是以都逗号分隔符做个单元格内容的划分, .xls存储比较复杂, .csv文件可以可以通过…2.读操作 读取文件 对于读取Excel文件的操作,使用了文件随机定位函数fseek(),它的一般调用格式如下: fseek…3.最新补充 2018.08.28 由于经常有朋友告诉我运行结果是0 ,并将他们的工程发到我…
Ⅶ 怎样用c语言读取excel文件
简单的方法是通过ODBC来实现: 具体实现 一、 包含Excel文件操作类头文件 #include "CSpreadSheet.h" 二、 新建Excel文件,并写入默认数据 // 新建Excel文件名及路径,TestSheet为内部表名 CSpreadSheet SS("c:\\Test.xls", "
Ⅷ 怎么用C/C++语言读取excel文件的某一行某一列
曾用C++ Builder 写过EXCEL操作。一般有两种方法:1,用ADO连续EXCEL数据库,这种方式,操作可用SQL来操作。2,用OLE方式,这种方式可以达到EXCEL中大部分的功能和操作。以下供参考:/************* 1— ADO *************///.h//—————————————————————————#ifndef Unit1H#define Unit1H//—————————————————————————#include <Classes.hpp>#include <Controls.hpp>#include <StdCtrls.hpp>#include <Forms.hpp>#include <ADODB.hpp>#include <DB.hpp>#include <DBGrids.hpp>#include <Dialogs.hpp>#include <Grids.hpp>//—————————————————————————class TForm1 : public TForm{__published:// IDE-managed Components TButton *btnOpen; TButton *btnExit; TOpenDialog *OpenDialog1; TButton *btnEx; TDataSource *DataSource1; TADOConnection *ADOConnection1; TADOQuery *ADOQuery1; TDBGrid *DBGrid1; void __fastcall btnExClick(TObject *Sender); void __fastcall btnOpenClick(TObject *Sender); void __fastcall btnExitClick(TObject *Sender);private:// User declarationspublic:// User declarations __fastcall TForm1(TComponent* Owner);};//—————————————————————————extern PACKAGE TForm1 *Form1;//—————————————————————————#endif//.cpp//—————————————————————————#include <vcl.h>#include <stdio.h>#pragma hdrstop#include "Unit1.h"//—————————————————————————#pragma package(smart_init)#pragma resource "*.dfm"TForm1 *Form1;//—————————————————————————__fastcall TForm1::TForm1(TComponent* Owner) : TForm(Owner){ DBGrid1->DataSource = DataSource1; DataSource1->DataSet = ADOQuery1; ADOQuery1->Connection = ADOConnection1; ADOConnection1->LoginPrompt = false;}//—————————————————————————void __fastcall TForm1::btnExClick(TObject *Sender){ if(ADOQuery1->Active && ADOQuery1->RecordCount>0 ) { int col; AnsiString s; FILE *fp; fp = fopen("c:\\out.txt","w+t"); if(fp==NULL) { Application->MessageBox("导出文件建立失败","提示"); return ; } col = ADOQuery1->Fields->Count; ADOQuery1->First(); while(!ADOQuery1->Eof) { s = ""; for(int i=0;i<col;i++) s += ADOQuery1->Fields->Fields[i]->AsString +"\t"; fprintf(fp,"%s\n",s.c_str()); ADOQuery1->Next(); } fclose(fp); } else { Application->MessageBox("没有需要导出的记录,请重新打开XLS文件","提示"); }}//—————————————————————————void __fastcall TForm1::btnOpenClick(TObject *Sender){ AnsiString sFile=""; AnsiString sCon; if(OpenDialog1->Execute()) { sFile = OpenDialog1->FileName; /* sCon = AnsiString("Driver={Microsoft Excel Driver (*.xls)};DBQ=") + sFile +"; "; */ sCon = AnsiString("Provider=MSDASQL.1;Persist Security Info=False;Extended Properties='DSN=Excel Files;DBQ=") + sFile +"'; "; } try { if(sFile!="") { ADOConnection1->Connected = False; ADOConnection1->ConnectionString = sCon; ADOConnection1->Connected = True; } } catch(…) { Application->MessageBox("连接XLS失败","提示"); return ; } if(ADOConnection1->Connected) { AnsiString sSQL = "Select * from [Sheet1$]"; ADOQuery1->SQL->Text = sSQL; ADOQuery1->Active = True; }}//—————————————————————————void __fastcall TForm1::btnExitClick(TObject *Sender){ Close(); }//—————————————————————————/************* 2– OLE *************/C++ Builder把Excel自动化对象的功能包装在下面的四个Ole Object Class函数中,应用人员可以很方便地进行调用。设置对象属性:void OlePropertySet(属性名,参数……);获得对象属性:Variant OlePropertyGet(属性名,参数……);调用对象方法:1) Variant OleFunction(函数名,参数……); 2) void OleProcere(过程名,参数……);在程序中可以用宏定义来节省时间:#define PG OlePropertyGet#define PS OlePropertySet#define FN OleFunction#define PR OleProcere举例:ExcelApp.OlePropertyGet("workbooks").OleFunction("Add");可写为ExcelApp.PG("workbooks").FN("Add");C++ Builder中使用OLE控制Excel2000,必须掌握Excel2000的自动化对象及Microsoft Word Visual Basic帮助文件中的关于Excel的对象、方法和属性。对象是一个Excel元素,属性是对象的一个特性或操作的一个方面,方法是对象可以进行的动作。首先定义以下几个变量:Variant ExcelApp,Workbook1,Sheet1,Range1;1、Excel中常用的对象是:Application,Workbooks,Worksheets等。 ★创建应用对象★ Variant ExcelApp; ExcelApp = Variant::CreateObject ("Excel.Application"); 或者 ExcelApp = CreateOleObject ("Excel.Application"); ★创建工作簿对象★ Variant WorkBook1; WorkBook1 = ExcelApp.PG("ActiveWorkBook"); ★创建工作表对象★ Variant Sheet1; Sheet1 = WorkBook1.PG("ActiveSheet"); ★创建区域对象★ Variant Range; Range = Sheet1.PG("Range","A1:A10"); 或者使用 Excel.Exec(PropertyGet("Range")<<"A1:C1").Exec(Procere("Select"));2、常用的属性操作: ★使Excel程序不可见★ ExcelApp.PS("Visible", (Variant)false); ★新建EXCEL文件★ ◎ 新建系统模板的工作簿 ExcelApp.PG("workbooks").FN("Add") //默认工作簿 ExcelApp.PG("workbooks").FN("Add", 1) //单工作表 ExcelApp.PG("workbooks").FN("Add", 2) //图表 ExcelApp.PG("workbooks").FN("Add", 3) //宏表 ExcelApp.PG("workbooks").FN("Add", 4) //国际通用宏表 ExcelApp.PG("workbooks").FN("Add", 5) //与默认的相同 ExcelApp.PG("workbooks").FN("Add", 6) //工作簿且只有一个表 或者使用ExcelApp的Exec方法 Excel.Exec(PropertyGet("Workbooks")).Exec(Procere("Add")); ◎ 新建自己创建的模板的工作簿 ExcelApp.PG("workbooks").FN("Add", "C:\\Temp\\result.xlt"); ★打开工作簿★ ExcelApp.PG("workbooks").FN("open", "路径名.xls") ★保存工作簿★ WorkBook1.FN("Save"); //保存工作簿 WorkBook1.FN("SaveAs", "文件名");//工作簿保存为,路径注意用"\\" ★退出EXCEL★ ExcelApp.FN ("Quit"); ExcelApp = Unassigned; 或者 ExcelApp.Exec(Procere("Quit")); ★操作工作表★ ◎ 选择选择工作表中第一个工作表 Workbook1.PG("Sheets", 1).PR("Select"); Sheet1 = Workbook1.PG("ActiveSheet"); ◎ 重命名工作表 Sheet1.PS("Name", "Sheet的新名字"); ◎ 当前工作簿中的工作表总数 int nSheetCount=Workbook1.PG("Sheets").PG("Count"); ★操作行和列★ ◎ 获取当前工作表中有多少行和多少列: Sheet1.PG("UsedRange").PG("Columns").PG("Count"); //列数 Sheet1.PG("UsedRange").PG("Rows").PG("Count"); //行数 ◎ 设置列宽 ExcelApp.PG("Columns", 1).PS("ColumnWidth", 22); 或者 Range = ExcelApp.PG("Cells", 1, 3); Range.PS("ColumnWidth", 22); ◎ 设置行高 ExcelApp.PG("Rows", 2).PS("RowHeight", 25); 或者 Range = ExcelApp.PG("Cells", 2, 1); Range.PS("RowHeight", 25); ◎ 在工作表最前面插入一行 Sheet1.PG("Rows", 1).PR("Insert"); ◎ 删除一行 ExcelApp.PG("Rows", 2).PR("Delete"); //将第2行删除 // 本文作者:ccrun ,如转载请保证本文档的完整性,并注明出处。 // 欢迎光临 C++ Builder 研究 www.ccrun.com // 摘自:http://www.ccrun.com/doc/go.asp?id=529 ★操作单元格★ ◎ 设置单元格字体 Sheet1.PG("Cells", 1, 1).PG("Font").PS("Name", "隶书"); //字体 Sheet1.PG("Cells", 2, 3).PG("Font").PS("size", 28); //大小 ◎ 设置所选区域字体 Range.PG("Cells").PG("Font").PS("Size", 28);// 本文转自 C++Builder研究 – http://www.ccrun.com/article.asp?i=529&d=0iezy5 Range.PG("Cells").PG("Font").PS("Color", RGB(0, 0, 255)); 其中参数的设置: Font Name : "隶书" //字体名称 Size : 12 //字体大小 Color : RGB(*,*,*) //颜色 Underline : true/false //下划线 Italic: true/false //斜体 ◎ 设置单元格格式为小数百分比 Sheet1.PG("Cells", 1, 1).PS("NumberFormatLocal", "0.00%"); ◎ 设定单元格的垂直对齐方式 Range = ExcelApp.PG("Cells", 3, 4); // 1=靠上 2=居中 3=靠下对齐 4=两端对齐 5=分散对齐 Range.PS("VerticalAlignment", 2); ◎ 设定单元格的文本为自动换行 Range = ExcelApp.PG("Cells", 3, 4); Range.PS("WrapText", true); ★单元格的合并★ ◎ Range = Sheet1.PG("Range", "A1:A2"); //A1和A2单元格合并 String strRange = "A" + IntToStr(j) + ":" + "C" + IntToStr(j); //比如:A1:C5 Range1=Sheet1.PG("Range", strRange.c_str()); //可以用变量控制单元格合并 Range1.FN("Merge", false); ★读写单元格★ ◎ 指定单元格赋值 String strValue = "abcdefg"; Sheet1.PG("Cells", 3, 6).PS("Value", strValue.c_str()); Sheet1.PG("Cells", j, 1).PS("Value", "总记录:" + String(j-6)); 或者使用 Excel.Exec(PropertyGet("Cells")<<1<<3).Exec(PropertySet("Value")<<15); ◎ 所选区域单元格赋值 Range.PG("Cells").PS("Value", 10); ◎ 所选区域行赋值 Range.PG("Rows",1).PS("Value", 1234); ◎ 工作表列赋值 Sheet1.PG("Columns",1).PS("Value", 1234); ◎ 读取取值语句: String strValue = Sheet1.PG("Cells", 3, 5).PG("Value");
Ⅸ 如何用C语言实现读取excel文件中的数据呢
基本思路基础实现方法同上篇文章《直接通过ODBC读、写Excel表格文件》相同,都是通过ODBC来把Excel表格文件当成数据库文件来进行读、写等操作,所以在Excel表格文件中写入的行头名必须是唯一的(不要重名,相当于数据库中的ID值)。本文中对Excel文件的操作都被封装进一个类CSpreadSheet中,通过它我们可以非常简便的实现各种Excel表格数据操作,并且可以对该类进行扩充来满足自己的需求。具体实现 一、 包含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);} 四、 对已存在Excel表格数据进行添加、插入、替换操作 // 初始化测试行数据,进行添加、插入及替换数据操作演示for (int k = 1; k <= 2; k++){ testRow.Add("Test");} SS.AddRow(testRow); // 添加到尾部SS.AddRow(testRow, 2); // 插入新行到第二行SS.AddRow(testRow, 6, true); // 替换原第四行来新的内容SS.AddCell("徐景周", 1,2); // 添加(不存在)或替换(存在)第二行,第一列单元格内容SS.Commit(); 五、 对已存在Excel表格数据进行行、列、单元格查询void CExcelAccessDlg::OnQuery() { CSpreadSheet SS("c:\\Test.xls", "TestSheet"); CStringArray Rows, Column; CString tempString = ""; UpdateData(); if(m_strRow == "" && m_strColumn == "") // 查询为空 { AfxMessageBox("行号、列号不能同时为空!"); return; } else if(m_strRow == "" && m_strColumn != "") // 查询指定列数据 { int iColumn = atoi(m_strColumn); int iCols = SS.GetTotalColumns(); if(iColumn > iCols) // 超出表范围查询时 { CString str; str.Format("表中总列数为: %d, ", iCols); AfxMessageBox(str + " 查询列数大于Excel表中总列数,请重新输入!"); return; } // 读取一列数据,并按行读出 if(!SS.ReadColumn(Column, iColumn)) { AfxMessageBox(SS.GetLastError()); return; } CString tmpStr; for (int i = 0; i < Column.GetSize(); i++) { tmpStr.Format("行号: %d, 列号: %d ,内容: %s\n", i+1,iColumn,Column.GetAt(i)); tempString += tmpStr; } AfxMessageBox(tempString); } else if(m_strRow != "" && m_strColumn == "") // 查询指定行数数据 { int iRow = atoi(m_strRow); int iRows = SS.GetTotalRows(); if(iRow > iRows) // 超出表范围查询时 { CString str; str.Format("表中总行数为: %d, ", iRows); AfxMessageBox(str + " 查询行数大于Excel表中总行数,请重新输入!"); return; } // 读取指定行数据 if(!SS.ReadRow(Rows, iRow)) { AfxMessageBox(SS.GetLastError()); return; } CString tmpStr; for (int i = 0; i < Rows.GetSize(); i++) { tmpStr.Format("行号: %d, 列号: %d ,内容: %s\n", iRow, i+1, Rows.GetAt(i)); tempString += tmpStr; } AfxMessageBox(tempString); } else if(m_strRow != "" && m_strColumn != "") // 查询指定单元格数据 { int iRow = atoi(m_strRow), iColumn = atoi(m_strColumn); int iRows = SS.GetTotalRows(), iCols = SS.GetTotalColumns(); if(iColumn > iCols) // 超出表范围查询时 { CString str; str.Format("表中总列数为: %d, ", iCols); AfxMessageBox(str + " 查询列数大于Excel表中总列数,请重新输入!"); return; } else if(iRow > iRows) { CString str; str.Format("表中总行数为: %d, ", iRows); AfxMessageBox(str + " 查询行数大于Excel表中总行数,请重新输入!"); return; } // 读取指定行、列单元格数据 if(!SS.ReadCell(tempString, iColumn, iRow)) { AfxMessageBox(SS.GetLastError()); return; } CString str; str.Format("行号: %d, 列号: %d ,内容: %s", iRow,iColumn,tempString); AfxMessageBox(str); } } 六、 将存在的Excel转换另存为指定分隔的文本文件 // 将原Excel文件转换为用分号分隔的文本,并另存为同名文本文件SS.Convert(";"); 七、 删除Excel中表格 SS. DeleteSheet(); // 删除Excel文件中所有表格SS. DeleteSheet(" TestSheet "); // 删除Excel中TextSheet表格 八、 获取Excel中总行数、总列数、当前行 int iCols = SS.GetTotalColumns(); // 总列数int iRows = SS.GetTotalRows(); // 总行数int iCurRow = SS.GetCurrentRow(); // 当前所在行号 九、 获取行头数据 CStringArray rowHeader;SS.GetFieldNames(rowHeader);CString tmpStr;for (int i = 0; i < rowHeader.GetSize(); i++){ tmpStr.Format("行号: %d, 列号: %d ,内容: %s\n", 1, i+1, rowHeader.GetAt(i)); tempString += tmpStr;}AfxMessageBox(tempString);最后,如果想知道详细实现细节的话,可以在下载示例源码后,仔细查看源码既可(内有详细注释)。
Ⅹ 如何用c语言读取excel文件
简单的方法是通过ODBC来实现: 具体实现 一、 包含Excel文件内操作类头文件 #include "CSpreadSheet.h" 二、 新建Excel文件,并写入默认数据容 // 新建Excel文件名及路径,TestSheet为内部表名 CSpreadSheet SS("c:\\Test.xls", "
未经允许不得转载:山九号 » c读写excel文件|怎么用C/C++语言读取excel文件的某一行某一列