BasicExcel的使用

class BasicExcel
|
void New(int sheets=3)
|
创建一个新工作薄,默认3张工作表
|
|
bool Load(const char* filename)
|
载入一个已存在的工作薄文件 |
|
bool Save()
|
保存当前工作薄到已载入文件
|
|
bool SaveAs(const char* filename)
|
保存当前工作薄到一个新文件
|
|
size_t GetTotalWorkSheets()
|
获取当前工作薄的工作表数目
|
|
BasicExcelWorksheet* GetWorksheet(size_t sheetIndex)
BasicExcelWorksheet* GetWorksheet(const char* name)
BasicExcelWorksheet* GetWorksheet(const wchar_t* name)
|
获取指定索引的工作表对象,索引从0开始,索引无效则返回值为NULL
获取指定名称的工作表对象,名称无效则返回值为NULL
|
|
BasicExcelWorksheet* AddWorksheet(int sheetIndex=-1)
BasicExcelWorksheet* AddWorksheet(const char* name, int sheetIndex=-1)
BasicExcelWorksheet* AddWorksheet(const wchar_t* name, int sheetIndex=-1)
|
添加指定索引的工作表,名称默认为SheetX,X从1开始,如果sheetIndex==-1,则默认添加到最后一个位置
添加指定名称和索引的工作表,如果sheetIndex==-1,则默认添加到最后一个位置
|
|
bool DeleteWorksheet(size_t sheetIndex)
bool DeleteWorksheet(const char* name)
bool DeleteWorksheet(const wchar_t* name)
|
删除指定索引或名称的工作表 |
|
char* GetAnsiSheetName(size_t sheetIndex)
wchar_t* GetUnicodeSheetName(size_t sheetIndex)
bool GetSheetName(size_t sheetIndex, char* name)
bool GetSheetName(size_t sheetIndex, wchar_t* name)
|
获取指定索引的工作表名称
|
|
bool RenameWorksheet(size_t sheetIndex, const char* to)
bool RenameWorksheet(size_t sheetIndex, const wchar_t* to)
bool RenameWorksheet(const char* from, const char* to)
bool RenameWorksheet(const wchar_t* from, const wchar_t* to)
|
重命名指定索引或名称的工作表
|
class BasicExcelWorksheet
|
char* GetAnsiSheetName()
wchar_t* GetUnicodeSheetName()
bool GetSheetName(char* name)
bool GetSheetName(wchar_t* name)
|
获取当前工作表的名称
|
|
bool Rename(const char* to)
bool Rename(const wchar_t* to)
|
重命名当前工作表
|
|
void Print(ostream& os, char delimiter=',', char textQualifier='\0')
|
输出整张工作表到指定输出流,指定列分隔字符和文本限定符
指定列分隔符为','和文本限定符为'\"',该函数可以用来保存当前工作表为CSV格式
|
|
size_t GetTotalRows()
|
获取当前工作表的总行数
|
|
size_t GetTotalCols()
|
获取当前工作表的总列数
|
|
BasicExcelCell* Cell(size_t row, size_t col)
|
获取指定行、列的单元格对象,行、列值从0开始,如果行值超过65535或者列值超过255则返回NULL
|
|
bool EraseCell(size_t row, size_t col)
|
清空指定行、列的单元格对象的内容
|
class BasicExcelCell
|
int Type() const
|
获取单元格值类型,包括以下值:
UNDEFINED,INT,DOUBLE,STRING,WSTRING |
|
bool Get(int& val) const
bool Get(double& val) const
bool Get(char* str) const
bool Get(wchar_t* str) const
|
从当前单元格获取指定类型的内容
|
|
size_t GetStringLength()
|
获取当前单元格字符串长度
|
|
int GetInteger() const
double GetDouble() const
const char* GetString() const
const wchar_t* GetWString() const
|
从当前单元格获取指定类型的内容
|
|
ostream& operator<<(ostream& os, const BasicExcelCell& cell)
|
输出当前单元格内容到输出流中
|
|
void Set(int val)
void Set(double val)
void Set(const char* str)
void Set(const wchar_t* str)
|
输出指定格式的内容到当前单元格 |
|
void SetInteger(int val)
void SetDouble(double val)
void SetString(const char* str)
void SetWString(const wchar_t* str)
|
输出指定格式的内容到当前单元格
|
|
void EraseContents()
|
清空当前单元格的内容 |
#include <QtCore/QCoreApplication>
#include "mythread.h" int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv); MyThread mythread;
mythread.setCurrentDirectory(QString("C:/Program Files/360"));
mythread.setStart(); return a.exec();
}
mythread.h
#ifndef MY_THREAD_H
#define MY_THREAD_H #include <QThread>
#include <QMutex>
#include <QWaitCondition> #include "BasicExcel.h" using namespace YExcel; class MyThread : public QThread
{
Q_OBJECT public:
MyThread();
~MyThread(); void setStart();
void setCurrentDirectory(QString strCurrentDirectory);
void recursiveTraverseDir(QString dirString); protected:
void run(); private:
void ExportToExcel(); private:
bool bRunning;
QWaitCondition waitRunning;
QMutex mutex; QString strCurrentDirectory;
QString strFileName;
int iFileSize; BasicExcel beObject;
BasicExcelWorksheet* bewCurrentSheet;
BasicExcelCell* becCurrentCell;
char strCurrentSheet[8];
int iCurrentRow;
int iSheetIndex;
}; #endif // MY_THREAD_H
#include <QDir>
#include <QFileInfo>
#include <Qt>
#include <QtGlobal>
#include <QtCore/qmath.h>
#include "mythread.h" MyThread::MyThread()
{
bRunning = false; beObject.New();
bewCurrentSheet = beObject.GetWorksheet("Sheet1");
iCurrentRow = 0;
iSheetIndex = 1; start();
} MyThread::~MyThread()
{
wait();
} void MyThread::setStart()
{
QMutexLocker locker(&mutex);
this->bRunning = true;
waitRunning.wakeOne();
} void MyThread::setCurrentDirectory(QString strCurrentDirectory)
{
QMutexLocker locker(&mutex);
this->strCurrentDirectory = strCurrentDirectory;
} void MyThread::run()
{
forever
{
{
QMutexLocker locker(&mutex);
if(!bRunning)
{
waitRunning.wait(&mutex);
}
} recursiveTraverseDir(strCurrentDirectory);
beObject.SaveAs("example.xls"); {
QMutexLocker locker(&mutex);
if(bRunning)
{
bRunning = false;
}
}
} } void MyThread::recursiveTraverseDir(QString dirString)
{
QDir dir(dirString);
if (!dir.exists())
{
return;
} dir.setFilter(QDir::Dirs | QDir::Files);
dir.setSorting(QDir::DirsFirst); QFileInfoList fileInfolist = dir.entryInfoList(); int i = 0;
bool bIsDir;
QFileInfo fileInfo; do{
fileInfo = fileInfolist.at(i);
if(fileInfo.fileName() == "." | fileInfo.fileName() == "..")
{
i++;
continue;
} bIsDir = fileInfo.isDir();
if (bIsDir)
{
recursiveTraverseDir(fileInfo.filePath());
}
else
{
strFileName = fileInfo.fileName();
iFileSize = qCeil((fileInfo.size()) / 1024); cout << strFileName.toLatin1().data() << "\t\t" << iFileSize << endl; ExportToExcel();
} msleep(50);
i++; }while(i < fileInfolist.size());
} void MyThread::ExportToExcel()
{
if(bewCurrentSheet)
{
becCurrentCell = bewCurrentSheet->Cell(iCurrentRow, 0);
becCurrentCell->SetString(strFileName.toLatin1().data()); becCurrentCell = bewCurrentSheet->Cell(iCurrentRow, 1);
becCurrentCell->SetInteger(iFileSize); iCurrentRow++;
}
}




BasicExcel的使用的更多相关文章
- BasicExcel说明文档
BasicExcel说明文档 BasicExcel原始链接:http://www.codeproject.com/Articles/13852/BasicExcel-A-Class-to-Read-a ...
- Excel文件操作方式比较
C++读取Excel的XLS文件的方法有很多,但是也许就是因为方法太多,大家在选择的时候会很疑惑. 由于前两天要做导表工具,比较了常用的方法,总结一下写个短文, 1.OLE的方式 这个大约是最常用的方 ...
- 在 VS2008 下操作 Excel 的方法总结
这些天做个软件,需要读取 Excel 并导入到数据库中,所以研究了一下在 VC 下操作 Excel 的方法,这里做个总结,以作备忘. 一.最常用的 OLE 自动化方式 这个方式应该说是功能最全的方 ...
- C++读写EXCEL文件OLE,java读写excel文件POI 对比
C++读写EXCEL文件方式比较 有些朋友问代码的问题,将OLE读写的代码分享在这个地方,大家请自己看.http://www.cnblogs.com/destim/p/5476915.html C++ ...
- C/C++读写excel文件 的几种方式
因为有些朋友问代码的问题,将OLE读写的代码分享在这个地方,大家请自己看. http://blog.csdn.net/fullsail/article/details/8449448 C++读取Exc ...
随机推荐
- 初学hadoop的个人历程
在学习hadoop之前,我就明确了要致力于大数据行业,成为优秀的大数据研发工程师的目标,有了大目标之后要分几步走,然后每一步不断细分,采用大事化小的方法去学习hadoop.下面开始叙述我是如何初 ...
- mfc学习---文档视图架构
MFC的AppWizard可以生成三种类型的应用程序:基于对话框的应用.单文档应用(SDI)和多文档应用(MDI). 一般情况下,采用文档/视结构的应用程序至少应由以下对象组成: 1. ...
- Rock-Paper-Scissors-Lizard-Spock Python实现
初学python,实现一些很有意思的小游戏是很能提高编程能力的. Rock-Paper-Scissors-Lizard-Spock http://en.wikipedia.org/wiki/Rock- ...
- 《React-Native系列》RN与native交互与数据传递
RN怎么与native交互的呢? 下面我们通过一个简单的Demo来实现:RN页面调起Native页面,Native页面选择电话本数据,将数据回传给RN展示. 首先是 Native侧 1.MainAct ...
- shell编程学习笔记之标准输入输出(read&echo)
2017-07-17 09:32:07 输入read: 用途: 从标准输入读取一行,或者从文件描述符FD(file descriptor)中读取一行,并且将其分割成字段. 用法: read [-ers ...
- fabric查看本地与远程主机信息
#!/usr/bin/pythonfrom fabric.api import *env.user='root'env.hosts=['172.10.224.183','172.10.224.132' ...
- SQLyog常用快捷键 - 转载
SQLyog常用快捷键 1. SQL格式化 F12 格式化当前行所在的SQL Ctrl+F12 格式化选中的SQL 2. 窗口操作 Ctrl+T 打开一个新的查询窗口 Alt+L ...
- 爬虫第六篇:scrapy框架爬取某书网整站爬虫爬取
新建项目 # 新建项目$ scrapy startproject jianshu# 进入到文件夹 $ cd jainshu# 新建spider文件 $ scrapy genspider -t craw ...
- 用JS判断IE版本的代码
方法一: 复制代码代码如下: <script language="javascript"> function getIE() { if(navigator.appNam ...
- 手把手教你用Vue2+webpack+node开发一个H5 app
手把手教你用Vue2+webpack+node开发一个H5 app 前一篇vue2 + webpack + node 开发一个小demo说到了用vue的一些基本用法,这一篇就讲一个复杂一点的更完整的 ...