- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章c++读取excel的代码详解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
c++如何读取excel?C++ ODBC操作excel全过程 。
想要通过ODBC直接读、写Excel表格文件,首先,应确保ODBC中已安装有Excel表格文件的驱动"MICROSOFT EXCEL DRIVER (*.XLS)"。然后,可根据下面步骤进行:
1. 在StdAfx.h文件中加入:
1
2
|
#include <afxdb.h>
#include <odbcinst.h>
|
2. 通过ODBC直接创建Excel文件(暂定文件名:Demo.xls) 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
//创建并写入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) 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
|
// 读取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的详细内容,希望我整理的内容能够帮助到大家.
原文链接:https://www.php.cn/csharp-article-443013.html 。
最后此篇关于c++读取excel的代码详解的文章就讲到这里了,如果你想了解更多关于c++读取excel的代码详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
全称“Java Virtual Machine statistics monitoring tool”(statistics 统计;monitoring 监控;tool 工具) 用于监控虚拟机的各种运
主要是讲下Mongodb的索引的查看、创建、删除、类型说明,还有就是Explain执行计划的解释说明。 可以转载,但请注明出处。  
1>单线程或者单进程 相当于短链接,当accept之后,就开始数据的接收和数据的发送,不接受新的连接,即一个server,一个client 不存在并发。 2>循环服务器和并发服务器
详解 linux中的关机和重启命令 一 shutdown命令 shutdown [选项] 时间 选项: ?
首先,将json串转为一个JObject对象: ? 1
matplotlib官网 matplotlib库默认英文字体 添加黑体(‘SimHei')为绘图字体 代码: plt.rcParams['font.sans-serif']=['SimHei'
在并发编程中,synchronized关键字是常出现的角色。之前我们都称呼synchronized关键字为重量锁,但是在jdk1.6中对synchronized进行了优化,引入了偏向锁、轻量锁。本篇
一般我们的项目中会使用1到2个数据库连接配置,同程艺龙的数据库连接配置被收拢到统一的配置中心,由DBA统一配置和维护,业务方通过某个字符串配置拿到的是Connection对象。  
实例如下: ? 1
1. MemoryCahe NetCore中的缓存和System.Runtime.Caching很相似,但是在功能上做了增强,缓存的key支持object类型;提供了泛型支持;可以读缓存和单个缓存
argument是javascript中函数的一个特殊参数,例如下文,利用argument访问函数参数,判断函数是否执行 复制代码 代码如下: <script
一不小心装了一个Redis服务,开了一个全网的默认端口,一开始以为这台服务器没有公网ip,结果发现之后悔之莫及啊 某天发现cpu load高的出奇,发现一个minerd进程 占了大量cpu,googl
今天写这个是为了 提醒自己 编程过程 不仅要有逻辑 思想 还有要规范 代码 这样可读性 1、PHP 编程规范与编码习惯最主要的有以下几点: 1 文件说明 2 funct
摘要:虚拟机安装时一般都采用最小化安装,默认没有lspci工具。一台测试虚拟网卡性能的虚拟机,需要lspci工具来查看网卡的类型。本文描述了在一个虚拟机中安装lspci工具的具体步骤。 由于要测试
1、修改用户进程可打开文件数限制 在Linux平台上,无论编写客户端程序还是服务端程序,在进行高并发TCP连接处理时,最高的并发数量都要受到系统对用户单一进程同时可打开文件数量的限制(这是因为系统
目录 算术运算符 基本四则运算符 增量赋值运算符 自增/自减运算符 关系运算符 逻
如下所示: ? 1
MapperScannerConfigurer之sqlSessionFactory注入方式讲解 首先,Mybatis中的有一段配置非常方便,省去我们去写DaoImpl(Dao层实现类)的时间,这个
Linux的网络虚拟化是LXC项目中的一个子项目,LXC包括文件系统虚拟化,进程空间虚拟化,用户虚拟化,网络虚拟化,等等,这里使用LXC的网络虚拟化来模拟多个网络环境。 本文从基本的网络设备讲
? 1
我是一名优秀的程序员,十分优秀!