1
0
mirror of https://github.com/QtExcel/QXlsx.git synced 2025-01-16 04:42:53 +08:00
QXlsx/README.ko.md
2018-06-14 15:48:31 +09:00

3.5 KiB
Raw Blame History

QXlsx

Read this in other languages: English, 🇰🇷 한국어

  • QXlsx는 엑셀 파일(*.xlsx)을 읽고 쓰는 라이브러리입니다.
    • QtXlsx가 더이상 지원되지 않기 때문에(2014), QtXlsx에 기반한 새로운 프로젝트를 만들었습니다. (2017-)
    • QXlsx는 개발언어로 C++를 사용합니다. (Qt 5.x 사용)
    • QXlsx는 정적 또는 동적 라이브러리를 사용하지 않아도 되도록 제작되었습니다.

라이센스

활용 예제 (Hello excel)

1 엑셀(xlsx) 파일 쓰기

QXlsx::Document xlsx;
xlsx.write("A1", "Hello Qt!"); // 셀(A,1)에 'Hello Qt!'값을 설정. 공유 문자열 타입으로 설정됨.
xlsx.saveAs("Test.xlsx"); // 'Test.xlsx'라는 이름으로 엑셀 파일을 저장.

2 엑셀(xlsx) 파일 읽기

Document xlsx("Test.xlsx"); // 엑셀 파일 읽기
if (!xlsx.isLoadPackage()) { 
	return; // 엑셀 파일 읽기 실패
}
int row = 1; int col = 2;
Cell* cell = xlsx.cellAt(row, col); // Cell의 pointer를 얻음 (행(row)는 1번째, 열(column)은 2번째)
if ( cell == NULL )
	continue; // 해당 행렬의 cell값이 설정되어 있지 않음
QVariant var = cell->readValue(); // 셀값을 읽음 (숫자(double), 날자(QDateTime), 문자열(QString) ...)
qDebug() << var; // 값 표시

설정하는 방법

테스트 환경

테스트된 환경은 다음과 같습니다.

  • Qt 5.10.1 (MingW/Windows 32bit)
  • Qt 5.9.2 (MingW/Windows 32bit)
  • Qt 5.9.1 (Visual Studio 2017/Windows 64bit)
  • Qt 5.9.1 (Visual Studio 2017/Windows 32bit)
  • Qt 5.9.1 (MingW/Windows 32bit)
  • Qt 5.9.1 (Ubuntu 16/Linux x64)
  • Qt 5.6.0 (MingW/Windows 32bit)
  • Qt 5.5.1 (MingW/Windows 32bit)
  • Qt 5.5.0 (Ubuntu 17/Linux i686)
  • Qt 5.2.0 (Ubuntu 14/Linux x64)
  • Qt 5.0.1 (MingW/Windows 32bit)

테스트 할 일

  • 다음과 같은 테스트들이 수행되어야 합니다.
    • 마이크로소프트 엑셀
    • 구글 스프레드쉬트
    • 리브레오피스 캘크 스프레드시트

  • 유니코드 테스트 ( ☁️ 파일 이름, ☁️ 파일 경로, ☀️ 자료값)

업그레이드 할 일

  • xlsx의 암복호화 기능 개발
  • Android에서 빌드 및 테스트

문의

내가 진행하는 유사한 프로젝트

  • Qxlnt https://github.com/j2doll/Qxlnt.git
    • Qxlnt는 xlnt가 Qt에서 사용될 수있게 해주는 도우미 프로젝트입니다.
    • xlnt는 xlsx Excel 파일을 사용하기에 훌륭한 라이브러리입니다.
    • xlnt를 Qt에서 사용하기 쉬운 방법을 찾고 있었습니다. 물론 cmake는 Qt와 호환되지만 사용하기가 쉽지 않습니다. 그래서 Qxlnt를 만들었습니다.