C++에서 엑셀 읽는 방법
c++如何读取excel?C++ ODBC操作excel全过程
推荐:《c++教程》
想要通过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; }
更多编程相关内容,请关注php中文网编程入门栏目!
위 내용은 C++에서 엑셀 읽는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











상수는 변수라고도 하며 일단 정의되면 프로그램이 실행되는 동안 그 값이 변경되지 않습니다. 따라서 변수를 고정된 값을 참조하는 상수로 선언할 수 있습니다. 텍스트라고도 합니다. 상수는 Const 키워드를 사용하여 정의해야 합니다. 구문 C 프로그래밍 언어에서 사용되는 상수의 구문은 다음과 같습니다. - consttypeVariableName; (또는) consttype*VariableName; 다양한 유형의 상수 C 프로그래밍 언어에서 사용되는 다양한 유형의 상수는 다음과 같습니다. 정수 상수 - 예: 1,0 ,34, 4567 부동 소수점 상수 - 예: 0.0, 156.89, 23.456 8진수 및 16진수 상수 - 예: 16진수: 0x2a, 0xaa.. 8진수

VS Code 및 Visual Studio C++ IntelliSense는 특히 대규모 프로젝트에서 작업할 때 라이브러리를 선택하지 못할 수 있습니다. #Include<wx/wx.h> 위로 마우스를 가져가면 "소스 파일 'string.h'를 열 수 없습니다."("wx/wx.h"에 따라 다름)라는 오류 메시지가 표시되며, 자동 완성 기능이 응답하지 않는 경우도 있습니다. 이 문서에서는 VSCode 및 VSC++ IntelliSense가 작동하지 않거나 라이브러리를 추출하지 않는 경우 수행할 수 있는 작업을 살펴보겠습니다. 내 Intellisense가 C++에서 작동하지 않는 이유는 무엇입니까? 대용량 파일을 작업할 때 IntelliSense가 가끔

오류 코드 8C230002로 인해 Xbox에서 콘텐츠를 구매하거나 시청할 수 없습니까? 일부 사용자가 본체에서 콘텐츠를 구매하거나 시청하려고 할 때 이 오류가 계속 발생합니다. 죄송합니다. Xbox 서비스에 문제가 있습니다. 나중에 다시 시도해 보세요. 이 문제에 대한 도움말을 보려면 www.xbox.com/errorhelp를 방문하세요. 상태 코드: 8C230002 이 오류 코드는 일반적으로 일시적인 서버 또는 네트워크 문제로 인해 발생합니다. 그러나 계정의 개인 정보 보호 설정이나 자녀 보호 기능 등 다른 이유로 인해 특정 콘텐츠를 구매하거나 시청하지 못할 수도 있습니다. Xbox 오류 코드 8C230002 수정 Xbox 콘솔에서 콘텐츠를 보거나 구매하려고 할 때 오류 코드 8C가 나타나는 경우

정수 배열 Arr[]을 입력으로 사용합니다. 목표는 재귀적 방법을 사용하여 배열에서 가장 큰 요소와 가장 작은 요소를 찾는 것입니다. 재귀를 사용하고 있으므로 길이 = 1에 도달할 때까지 전체 배열을 반복한 다음 기본 사례를 구성하는 A[0]을 반환합니다. 그렇지 않은 경우 현재 요소는 현재 최소값 또는 최대값과 비교되고 해당 값은 후속 요소에 대해 반복적으로 업데이트됩니다. 이에 대한 다양한 입력 및 출력 시나리오를 살펴보겠습니다. −Input −Arr={12,67,99,76,32} Output −배열의 최대값: 99 설명 &mi

25일 뉴스에 따르면 중국동방항공은 성과보고회에서 C919 여객기의 최신 진행 상황을 공개했다. 회사에 따르면 COMAC과 체결한 C919 구매 계약은 2021년 3월 공식 발효됐으며, 첫 번째 C919 항공기는 2022년 말까지 인도됐다. 조만간 해당 항공기가 정식으로 실제 운항에 들어갈 것으로 예상된다. 중국동방항공은 상하이를 C919 상용 운항의 주요 기지로 삼아 2022년과 2023년 총 5대의 C919 여객기를 도입할 계획이다. 회사 측은 향후 도입 계획은 실제 운행 상황과 노선망 계획 등을 토대로 결정할 예정이라고 밝혔다. 편집자의 이해에 따르면 C919는 완전히 독립적인 지적 재산권을 보유하고 국제적으로 인정된 감항성 표준을 준수하는 중국의 차세대 글로벌 단일 통로 간선 여객기입니다. 해야 한다

숫자를 다양한 형식으로 표시하는 것은 학습의 기본 코딩 문제 중 하나입니다. 조건문 및 루프문과 같은 다양한 코딩 개념. 별표와 같은 특수 문자를 사용하여 삼각형이나 사각형을 인쇄하는 다양한 프로그램이 있습니다. 이 기사에서는 C++의 사각형처럼 나선형 형태로 숫자를 인쇄합니다. 행 수 n을 입력으로 사용하고 왼쪽 상단에서 시작하여 오른쪽, 아래, 왼쪽, 위, 다시 오른쪽 등으로 이동합니다. 숫자가 포함된 나선형 패턴 123456724252627282982340414243309223948494431102138474645321120373635343312191817161514

C에서 void는 특정 유형이 없는 데이터를 의미하는 빈 유형을 나타내는 데 사용되는 특수 키워드입니다. C 언어에서 void는 주로 다음 세 가지 측면에서 사용됩니다. 함수 반환 유형은 void입니다. C 언어에서 함수는 int, float, char 등과 같은 다양한 반환 유형을 가질 수 있습니다. 그러나 함수가 어떤 값도 반환하지 않는 경우 반환 유형을 void로 설정할 수 있습니다. 이는 함수가 실행된 후에 특정 값을 반환하지 않음을 의미합니다. 예: voidhelloWorld()

프로그래밍 언어의 인기도를 측정하는 벤치마크 중 하나인 TIOBE 프로그래밍 커뮤니티 지수(TIOBE 프로그래밍 커뮤니티 지수)에 따르면 전 세계 엔지니어, 강좌, 벤더, 검색 엔진으로부터 데이터를 수집하여 평가합니다. 최근 2024년 1월 TIOBE 지수가 발표되었으며, 2023년 공식 프로그래밍 언어 순위가 발표되었습니다. C#이 TIOBE 2023 올해의 프로그래밍 언어상을 수상한 것은 C#이 23년 만에 처음입니다. TIOBE의 공식 보도 자료에 따르면 C#은 20년 넘게 상위 10위 안에 들었으며 이제 4대 언어를 따라잡으며 1년 만에 가장 큰 성장(+1.43%)을 달성한 프로그래밍 언어가 되었습니다. 이 상을 받는 것은 당연한 일입니다. 2위는 스크래치(+0.83%)와 포트란(+0)입니다.
