c++ 读写Excel及数据导入SQLServer
c++ 读写Excel及数据导入SQLServer
C++操作Excel ,网上的资料还是比较多的,写这篇文章也是分享给初学者一些经验。
本人 觉得CSpreadSheet.h这个类封装的还不错。下面我就如何使用这个类介绍一下,
- ////////////////main.cpp/////////////////////////////////////////////////////
- #include <string>
- #include<afxdb.h>
- #include<odbcinst.h>
- #include "CSpreadSheet.h"
- using std::string;
- #pragma warning(disable:4146)
- #pragma warning(disable:4786)
- #import "C:\Program Files\Common Files\System\ado\msado15.dll" no_namespace rename("EOF","adoEOF")
- //插入到数据库
- bool InsertExcel(CString str1,CString str2)
- {
- try
- {
- CDatabase m_db;
- if (!m_db.IsOpen())
- {
- m_db.OpenEx("Dsn=MyDatabase;uid=Administrator;trusted_connection=Yes;app=Microsoft? Visual Studio? 2005;wsid=LIYU\SQLEXPRESS;database=MyDdatabase",0);
- }
- CString sql("insert into Students(myname,age) values('"+ str1+"','"+str2+"')");
- m_db.ExecuteSQL(sql);
- if(m_db.IsOpen())
- {
- m_db.Close();
- }
- return true;
- }
- catch(_com_error e)
- {
- string ErrorMessage("数据库连接关闭失败:"),Description,Source;
- Description=e.Description();
- Source=e.Source();
- ErrorMessage+=e.ErrorMessage();
- ErrorMessage=ErrorMessage+"\r\n"+Source+"\r\n"+Description;
- ::MessageBox(NULL,ErrorMessage.c_str(),"错误",MB_OK);
- return false;
- }
- }
- //获取路径
- CString GetAddr()
- {
- CString sFile,sPath;
- //获取主程序所在路径,存在sPath中
- GetModuleFileName(NULL,sPath.GetBufferSetLength (MAX_PATH+1),MAX_PATH);
- sPath.ReleaseBuffer ();
- int nPos;
- nPos=sPath.ReverseFind ('\\');
- sPath=sPath.Left (nPos);
- sFile = sPath + "\\Demo.xls";
- return sFile;
- }
- //得到驱动
- CString 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;
- }
- //读取Excel
- void ReadFromExcel()
- {
- TRY
- {
- CString str=GetAddr();
- if(str.IsEmpty())
- ::MessageBox(NULL,"无法获取当前路径",NULL,MB_OK);
- else
- {
- CSpreadSheet SS(str,"Students");
- CStringArray Rows, Column;
- CString strContents = "";
- CString sItem[3]={"0"};
- for (int i = 2; i < SS.GetTotalRows()+1; i++)
- {
- // 读取一行
- SS.ReadRow(Rows, i);
- strContents.Empty();
- for (int j = 0; j < Rows.GetSize(); j++)
- {
- strContents = Rows.GetAt(j);
- sItem[j]=strContents;
- printf("%s\t",sItem[j]);
- }
- printf("\n");
- if(!InsertExcel(sItem[1],sItem[2]))
- {
- ::MessageBox(NULL,"导入数据出错","错误",MB_OK);
- return;
- }
- }
- }
- }
- CATCH(CDBException, e)
- {
- // 数据库操作产生异常时...
- AfxMessageBox("数据库错误: " + e->m_strError);
- }
- END_CATCH;
- }
- //写Excel
- void WriteFromExcel(int num,CString str1,CString str2,CString str3)
- {
- CString path=GetAddr();
- if(path.IsEmpty())
- ::MessageBox(NULL,"获取路径错误",NULL,MB_OK);
- else
- {
- // 新建Excel文件名及路径,TestSheet为内部表名
- CSpreadSheet SS(path,"StudentsOut");
- CStringArray sampleArray, testRow;
- SS.BeginTransaction();
- // 加入标题
- sampleArray.RemoveAll();
- sampleArray.Add("ID");
- sampleArray.Add("myname");
- sampleArray.Add("age");
- SS.AddHeaders(sampleArray);
- testRow.Add(str1);
- testRow.Add(str2);
- testRow.Add(str3);
- SS.AddRow(testRow,num,true);
- SS.Commit();
- }
- }
- //查询
- bool selectExcel()
- {
- _ConnectionPtr m_pConnection; //connection object's pointer
- _CommandPtr m_pCommand; //command object's pointer
- _ParameterPtr m_pParameter; //Parameter object's pointer
- _RecordsetPtr m_pRecordset;
- HRESULT hr;
- try
- {
- // 创建连接对象
- hr=m_pConnection.CreateInstance(__uuidof(Connection));
- m_pRecordset.CreateInstance(__uuidof(Recordset));
- if(!SUCCEEDED(hr)) return FALSE;
- // 连接数据库
- m_pConnection->ConnectionString="File Name=LinkDatabase.udl";
- m_pConnection->ConnectionTimeout=20;//等待连接的时间为20s
- hr=m_pConnection->Open("","","",adModeUnknown);
- if(!SUCCEEDED(hr)) return FALSE;
- // 查询数据库
- _variant_t RecordsAffected;
- std::string sql= "select * from Students";
- char * str=(char*)sql.c_str();
- m_pRecordset=m_pConnection->Execute(str,&RecordsAffected,adCmdText);
- //m_pRecordset-> Open(str, _variant_t((IDispatch *)m_pConnection,true),adOpenStatic,adLockOptimistic,adCmdText);
- int i=2;
- // 遍历查询结果
- while (!m_pRecordset->adoEOF)
- {
- printf("%s\t",(char*)(_bstr_t)m_pRecordset->GetCollect("ID"));
- printf("%s\t",(char*)(_bstr_t)m_pRecordset->GetCollect("myname"));
- printf("%s\n",(char*)(_bstr_t)m_pRecordset->GetCollect("age"));
- CString str1=(CString)m_pRecordset->GetCollect("ID");
- CString str2=(CString)m_pRecordset->GetCollect("myname");
- CString str3=(CString)m_pRecordset->GetCollect("age");
- WriteFromExcel(i++,str1,str2,str3);
- m_pRecordset->MoveNext();
- }
- m_pRecordset->Close();
- // 关闭数据库连接
- if(m_pConnection!=NULL)
- {
- m_pConnection->Close();
- m_pConnection = NULL ;
- }
- }
- catch(_com_error e)
- {
- string ErrorMessage("数据库连接关闭失败:"),Description,Source;
- Description=e.Description();
- Source=e.Source();
- ErrorMessage+=e.ErrorMessage();
- ErrorMessage=ErrorMessage+"\r\n"+Source+"\r\n"+Description;
- ::MessageBox(NULL,ErrorMessage.c_str(),"错误",MB_OK);
- return FALSE;
- }
- }
- int main()
- {
- CoInitialize(NULL);
- // ReadFromExcel();//读取Excel到数据库
- selectExcel();
- CoUninitialize( );
- system("pause");
- return 0;
- }
- ////////////////mian.cpp////////////////////////////////////////////////
c++ 读写Excel及数据导入SQLServer的更多相关文章
- 将Excel中数据导入数据库(二)
在上篇文章中介绍到将Excel中数据导入到数据库中,但上篇文章例子只出现了nvachar类型,且数据量很小.今天碰到将Excel中数据导入数据库中的Excel有6419行,其中每行均有48个字段,有i ...
- Excel表数据导入Sql Server数据库中
Excel表数据导入Sql Server数据库的方法很多,这里只是介绍了其中一种: 1.首先,我们要先在test数据库中新建一个my_test表,该表具有三个字段tid int类型, tname nv ...
- Excel的数据导入到PB的DW中
Excel的数据导入到PB的DW中//==================================================================== // Event:cb_ ...
- Visual Basic 2012 借助DataGridView控件将Excel 2010数据导入到SQL server 2012
(注:注释的颜色原本为绿色,在这里变为黑色,有点不便,但不会造成阅读影响.放入Visual Basic2012代码编辑器后会还原成绿色.) 摘 要:DataGridView控件作为数据传输的中介,只 ...
- 将Excel中数据导入数据库(三)
上篇文章将Excel中数据导入数据库时,将从Excel读入的数据均转换成了数据库相应字段的类型,其实这是没有必要的,因为对于数据库各种类型的插入,均可以字符串格式插入.比如表WQ_SWMSAR_A字段 ...
- 将Excel中数据导入数据库(一)
在工作中经常要将Excel中数据导入数据库,这里介绍一种方法. 假如Excel中的数据如下: 数据库建表如下: 其中Id为自增字段: Excel中数据导入数据库帮助类如下: using System; ...
- SQL SERVER 与ACCESS、EXCEL的数据导入导出转换
* 说明:复制表(只复制结构,源表名:a 新表名:b) select * into b from a where 1<>1 * 说明:拷贝表(拷贝数据,源表名:a 目标表名:b) ...
- Excel表数据导入数据库表中
***Excel表数据导入到数据库表中 通过数据库表的模板做成‘Excel’表的数据导入到数据库相应的表中(注意:主表 和 从表的关系,要先导‘主表’在导入从表) 过程:通过数据库的导入工具—先导入为 ...
- 把Excel的数据导入到数据库
将Excel作为数据源,将数据导入数据库,是SSIS的一个简单的应用,下图是示例Excel,数据列是code和name 第一部分,Excel中的数据类型是数值类型 1,使用SSDT创建一个packag ...
随机推荐
- LeetCode 136. Single Number(只出现一次的数字)
LeetCode 136. Single Number(只出现一次的数字)
- 获取 web 项目的绝对路径
获取 web 项目的绝对路径 <% String path = request.getContextPath(); String basePath = request.getScheme()+& ...
- 尝试php命令行脚本多进程并发执行
php不支持多线程,但是我们可以把问题转换成“多进程”来解决.由于php中的pcntl_fork只有unix平台才可以使用,所以本文尝试使用popen来替代. 下面是一个例子: 被并行调用的子程序 ...
- golang中接口interface和struct结构类的分析
再golang中,我们要充分理解interface和struct这两种数据类型.为此,我们需要优先理解type的作用. type是golang语言中定义数据类型的唯一关键字.对于type中的匿名成员和 ...
- http request GET 乱码分析
提交一个GET请求 在浏览器地址栏或搜索框输入地址:http://www.baidu.com/content/衣服?keyword=衬衣 其中的中文会被浏览器进行编码,具体编码情况请参考阮大神:关于U ...
- y450 archlinux cuda6.5
y450 archlinux cuda6.5 January 28, 2018 4:11 PM archlinux是最新更新版本,gcc版本到了7.几,太新了. [qiangge@lqspc ~]$ ...
- 【SQL】175. Combine Two Tables
Table: Person +-------------+---------+ | Column Name | Type | +-------------+---------+ | PersonId ...
- Yii apache配置站点出现400 Bad Request 的解决方法
<VirtualHost *:80> ServerName localhost ServerAlias localhost DocumentRoot "/www/frogCms/ ...
- 【BZOJ 3235】 3235: [Ahoi2013]好方的蛇 (单调栈+容斥原理)
3235: [Ahoi2013]好方的蛇 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 187 Solved: 95 Description 有一天, ...
- 求n的阶乘 (python实现)
描述 给定一个数n,范围为0≤n≤100,请你编程精确的求出n的阶乘n!. 输入 输入数据有多行,每行一个整数n,当n<0时输入结束. 输出 输出n的阶乘. 样例输入 1234-1 样例输出 1 ...