C++将DBGrid中数据导出到Word和Excel
2008-03-08 10:35:42 作者
经常看到有网友发帖子询问如何将DBGrid中的内容导出到Excel或Word文档中,于是笔者花了点时间写了以下两个函数,分别实现将DBGrid中数据导出到Word和Excel文档。需要注重的是DBGrid中的数据并不代表数据库中所有的数据,因为数据集在打开的时候有可能进行了筛选,取决于使用者如何打开这个数据集,总之就是DBGrid中显示多少数据,就导出多少。
一、将DBGrid中的内容导出到Word文档
//---------------------------------------------------------------------------
// 将DBGrid中的数据导出到Word文档
//---------------------------------------------------------------------------
void __fastcall DBGrid2Word(TDBGrid *dbg, String strDocFile)
{
if(!dbg-%26gt;DataSource-%26gt;DataSet-%26gt;Active) // 数据集没有打开就返回
return;
Variant vWordApp, vTable, vCell;
try
{
vWordApp = Variant::CreateObject("Word.Application");
}
catch(...)
{
MessageBox(0, "启动 Word 出错, 可能是没有安装Word.","DBGrid2Word", MB_OK MB_ICONERROR);
vWordApp = Unassigned;
return;
}
// 隐藏Word界面
vWordApp.OlePropertySet("Visible", false);
// 新建一个文档
vWordApp.OlePropertyGet("Documents").OleFunction("Add");
Variant vSelect = vWordApp.OlePropertyGet("Selection");
// 设置一下字体,大小
vSelect.OlePropertyGet("Font").OlePropertySet("Size", dbg-%26gt;Font-%26gt;Size);
vSelect.OlePropertyGet("Font").OlePropertySet("Name", dbg-%26gt;Font-%26gt;Name.c_str());
// 要插入表格的行数
int nRowCount(dbg-%26gt;DataSource-%26gt;DataSet-%26gt;RecordCount + 1);
nRowCount = nRowCount %26lt; 2? 2: nRowCount;
// 要插入表格的列数
int nColCount(dbg-%26gt;Columns-%26gt;Count);
nColCount = nColCount %26lt; 1? 1: nColCount;
// 在Word文档中插入与DBGrid行数列数基本相同的一个表格
vWordApp.OlePropertyGet("ActiveDocument").OlePropertyGet("Tables").OleProcedure("Add",
vSelect.OlePropertyGet("Range"),
nRowCount, // 行数
nColCount, // 列数
1, // DefaultTableBehavior:=wdWord9TableBehavior
0); // AutoFitBehavior:=wdAutoFitFixed
// 操作这个表格
vTable = vWordApp.OlePropertyGet("ActiveDocument").
OleFunction("Range").OlePropertyGet("Tables").OleFunction("Item", 1);
// 设置单元格的宽度
for(int i=0; i%26lt;nColCount; i++)
{
int nColWidth = dbg-%26gt;Columns-%26gt;Items[i]-%26gt;Width;
vTable.OlePropertyGet("Columns").OleFunction("Item", i + 1)
.OlePropertySet("PreferredWidthType", 3); // wdPreferredWidthPoints
vTable.OlePropertyGet("Columns").OleFunction("Item", i + 1)
.OlePropertySet("PreferredWidth", nColWidth);
}
// 先将列名写入Word表格
for(int j=0; j%26lt;dbg-%26gt;Columns-%26gt;Count; j++)
{
vCell = vTable.OleFunction("Cell", 1, j + 1);
vCell.OlePropertySet("Range", dbg-%26gt;Columns-%26gt;Items[j]-%26gt;FieldName.c_str());
// 列名单元格背景颜色 // wdColorGray125
vCell.OlePropertyGet("Shading").OlePropertySet("BackgroundPatternColor", 14737632);
}
// 将DBGrid中的数据写入Word表格
dbg-%26gt;DataSource-%26gt;DataSet-%26gt;First();
for(int i=0; i%26lt;nRowCount; i++)
{
// 63 63 72 75 6E 2E 63 6F 6D
for(int j=0; j%26lt;dbg-%26gt;Columns-%26gt;Count; j++)
{
vCell = vTable.OleFunction("Cell", i + 2, j + 1);
vCell.OlePropertySet("Range",
dbg-%26gt;DataSource-%26gt;DataSet-%26gt;FieldByName(
dbg-%26gt;Columns-%26gt;Items[j]-%26gt;FieldName)-%26gt;AsString.c_str());
}
dbg-%26gt;DataSource-%26gt;DataSet-%26gt;Next();
}
// 保存Word文档并退出
vWordApp.OlePropertyGet("ActiveDocument").OleProcedure("SaveAs", strDocFile.c_str());
vWordApp.OlePropertyGet("ActiveDocument").OleProcedure("Close");
Application-%26gt;ProcessMessages();
vWordApp.OleProcedure("Quit");
Application-%26gt;ProcessMessages();
vWordApp = Unassigned;
// 工作结束
MessageBox(0, "DBGrid2Word 转换结束!","DBGrid2Word", MB_OK MB_ICONINFORMATION);
}
二、将DBGrid中的内容导出到Excel文档
//---------------------------------------------------------------------------
// 将DBGrid中的数据导出到Excel文档
//---------------------------------------------------------------------------
void __fastcall DBGrid2Excel(TDBGrid *dbg, String strXlsFile)
{
if(!dbg-%26gt;DataSource-%26gt;DataSet-%26gt;Active) // 数据集没有打开就返回
return;
Variant vExcelApp, vSheet;
try
{
vExcelApp = Variant::CreateObject("Excel.Application");
}
catch(...)
{
MessageBox(0, "启动 Excel 出错, 可能是没有安装Excel.","DBGrid2Excel", MB_OK MB_ICONERROR);
return;
}
// 隐藏Excel界面
vExcelApp.OlePropertySet("Visible", false);
// 新建一个工作表
vExcelApp.OlePropertyGet("Workbooks").OleFunction("Add", 1); // 工作表
// 操作这个工作表
vSheet = vExcelApp.OlePropertyGet("ActiveWorkbook").OlePropertyGet("Sheets", 1);
// 设置Excel文档的字体
vSheet.OleProcedure("Select");
vSheet.OlePropertyGet("Cells").OleProcedure("Select");
vExcelApp.OlePropertyGet("Selection").OlePropertyGet("Font").OlePropertySet("Size", dbg-%26gt;Font-%26gt;Size);
vExcelApp.OlePropertyGet("Selection").OlePropertyGet("Font").OlePropertySet("Name",dbg-%26gt;Font-%26gt;Name.c_str());
vExcelApp.OlePropertyGet("Selection").OlePropertyGet("Font").OlePropertySet("FontStyle", "常规");
vSheet.OlePropertyGet("Cells", 1, 1).OleProcedure("Select");
// 表格的行数
int nRowCount(dbg-%26gt;DataSource-%26gt;DataSet-%26gt;RecordCount + 1);
nRowCount = nRowCount %26lt; 2? 2: nRowCount;
// 表格的列数
int nColCount(dbg-%26gt;Columns-%26gt;Count);
nColCount = nColCount %26lt; 1? 1: nColCount;
// 设置单元格的宽度
for(int i=0; i%26lt;nColCount; i++)
{
int nColWidth = dbg-%26gt;Columns-%26gt;Items[i]-%26gt;Width;
vExcelApp.OlePropertyGet("Columns", i + 1).OlePropertySet("ColumnWidth", nColWidth / 7);
}
// 先将列名写入Excel表格
for(int j=0; j%26lt;dbg-%26gt;Columns-%26gt;Count; j++)
{
// 标题行的行高
vExcelApp.OlePropertyGet("Rows", 1).OlePropertySet("RowHeight", 20);
vSheet.OlePropertyGet("Cells", 1, j + 1)
.OlePropertySet("Value", dbg-%26gt;Columns-%26gt;Items[j]-%26gt;FieldName.c_str());
// 设置列名单元格的背景色
Variant vInter = vSheet.OlePropertyGet( "Cells", 1, j + 1).OlePropertyGet("Interior");
vInter.OlePropertySet("ColorIndex", 15); // 灰色
vInter.OlePropertySet("Pattern", 1); // xlSolid
vInter.OlePropertySet("PatternColorIndex", -4105); // xlAutomatic
}
// 将DBGrid中的数据写入Excel表格
dbg-%26gt;DataSource-%26gt;DataSet-%26gt;First();
for(int i=0; i%26lt;nRowCount; i++)
{
// 普通数据行的行高16
vExcelApp.OlePropertyGet("Rows", i + 2).OlePropertySet("RowHeight", 16);
// 63 63 72 75 6E 2E 63 6F 6D
for(int j=0; j%26lt;dbg-%26gt;Columns-%26gt;Count; j++)
{
vSheet.OlePropertyGet("Cells", i + 2, j + 1).OlePropertySet("Value",
dbg-%26gt;DataSource-%26gt;DataSet-%26gt;FieldByName(
dbg-%26gt;Columns-%26gt;Items[j]-%26gt;FieldName)-%26gt;AsString.c_str());
}
dbg-%26gt;DataSource-%26gt;DataSet-%26gt;Next();
}
// 保存Excel文档并退出
vExcelApp.OlePropertyGet("ActiveWorkbook").OleFunction("SaveAs", strXlsFile.c_str());
vExcelApp.OleFunction("Quit");
vSheet = Unassigned;
vExcelApp = Unassigned;
// 工作结束
MessageBox(0, "DBGrid2Excel 转换结束!","DBGrid2Excel", MB_OK MB_ICONINFORMATION);
}
相关文章
- · 一个导出Excel非常快的类
- · DBGrid单元格画圆圈
- · 如何在delphi5中实现对word文档页眉的设置?
- · 从DBGrid,StringGrid导出Excel
- · 在Delphi中使用CreateOleObject方法对WORD文件进行操作
- · 快速导出数据到Excel(三):利用Excel内置功能
- · 快速导出数据到Excel(一):利用剪贴板
- · 如何将几个DBGRID里的内容导入同一个EXCEL表中....的问题
- · DBGrid中用光标键控制Cell
- · 点击DBGrid的Title对查询结果排序
- · 拷贝DBGrid当前行
- · 如何在DBGRID或者STRINGGRID中实现用滚轮进行翻页的功能,就象浏览网页一样
- · 关于DBGrid的分类颜色显示
- · 巧用DBGrid控件的Sort属性实现“点击标题栏自动排序功能”。
- · DBGrid使用全书(五)
- · DBGrid使用全书(三)
- · DBGrid使用全书(四)
- · DBGrid使用全书(二)
- · 给DBGrid添加鼠标滚动事件
- · 对DBGrid中的列进行显示与否的设置
- · 让你的DBGrid竖着站(1)
