用OLE操作Excel资料

 
要在应用程序中控制Excel的运行,首先必须在编制自动化客户程序时包含Comobj.hpp
#include "Comobj.hpp"
C++ BuilderExcel自动化对象的功能包装在下面的四个Ole Object Class函数中,应用人员可以很方便地进行调用。
设置对象属性:void        OlePropertySet(属性名,参数……);
获得对象属性:Variant     OlePropertyGet(属性名,参数……);
调用对象方法
1) Variant  OleFunction(函数名,参数……);
2) void     OleProcedure(过程名,参数……);  
举例:ExcelApp.OlePropertyGet("workbooks").OleFunction("Add");
可写为:ExcelApp.OlePropertyGet("workbooks").FN("Add");
 
C++ Builder中使用OLE控制Excel2000,必须掌握Excel2000的自动化对象及Microsoft Word Visual Basic帮助文件中的关于Excel的对象、方法和属性。对象是一个Excel元素,属性是对象的一个特性或操作的一个方面,方法是对象可以进行的动作。
首先定义以下几个变量:
Variant ExcelApp,Workbook1,Sheet1,Range1;
1Excel中常用的对象是:Application,Workbooks,Worksheets等。
      创建应用对象★
Variant ExcelApp;
ExcelApp = Variant::CreateObject ("Excel.Application");
 或者
ExcelApp = CreateOleObject ("Excel.Application");
      创建工作簿对象★
Variant WorkBook1;
WorkBook1 = ExcelApp.OlePropertyGet("ActiveWorkBook");
      创建工作表对象★
Variant Sheet1;
Sheet1 = WorkBook1.OlePropertyGet("ActiveSheet");
      创建区域对象★
    Variant Range;
Range = Sheet1.OlePropertyGet("Range","A1:A10");    
或者使用
Excel.Exec(PropertyGet("Range")<<"A1:C1").Exec(Procedure("Select"));
2、常用的属性操作:
      使Excel程序不可见
ExcelApp.OlePropertySet("Visible", (Variant)false);
      新建EXCEL文件
      新建系统模板的工作簿
ExcelApp.OlePropertyGet("workbooks").OleFunction("Add")      //默认工作簿
ExcelApp.OlePropertyGet("workbooks").OleFunction("Add", 1)   //单工作表
ExcelApp.OlePropertyGet("workbooks").OleFunction("Add", 2)   //图表  
ExcelApp.OlePropertyGet("workbooks").OleFunction("Add", 3)   //宏表
ExcelApp.OlePropertyGet("workbooks").OleFunction("Add", 4)   //国际通用宏表
ExcelApp.OlePropertyGet("workbooks").OleFunction("Add", 5)   //与默认的相同
ExcelApp.OlePropertyGet("workbooks").OleFunction("Add", 6)   //工作簿且只有一个表
或者使用ExcelAppExec方法
Excel.Exec(PropertyGet("Workbooks")).Exec(Procedure("Add"));
      新建自己创建的模板的工作簿
 ExcelApp.OlePropertyGet("workbooks").OleFunction("Add", "C://Temp//result.xlt");
      打开工作簿★
ExcelApp.OlePropertyGet("workbooks").OleFunction("open", "路径名.xls")  
      保存工作簿★
WorkBook1.OleFunction("Save");            //保存工作簿
WorkBook1.OleFunction("SaveAs", "文件名");//工作簿保存为,路径注意用"//"
      退出EXCEL★
ExcelApp.OleFunction("Quit");
ExcelApp = Unassigned;
或者
ExcelApp.Exec(Procedure("Quit"));
      操作工作表★
      选择选择工作表中第一个工作表
Workbook1.OlePropertyGet("Sheets", 1).OleProcedure("Select");
Sheet1 = Workbook1.OlePropertyGet("ActiveSheet");
      重命名工作表
Sheet1.OlePropertyGet("Name", "Sheet的新名字");
                     ◎当前工作簿中的工作表总数
                             int nSheetCount=Workbook1.OlePropertyGet("Sheets").OlePropertyGet("Count");  
      操作行和列★
      获取当前工作表中有多少行和多少列:
Sheet1.OlePropertyGet("UsedRange").OlePropertyGet("Columns").OlePropertyGet("Count"); //列数
Sheet1.OlePropertyGet("UsedRange").OlePropertyGet("Rows").OlePropertyGet("Count");    //行数
      设置列宽
ExcelApp.OlePropertyGet("Columns", 1).OlePropertySet("ColumnWidth", 22);
或者
Range = ExcelApp.OlePropertyGet("Cells", 1, 3);
Range.OlePropertySet("ColumnWidth", 22);     
      设置行高
ExcelApp.OlePropertyGet("Rows", 2).OlePropertySet("RowHeight", 25);
或者
Range = ExcelApp.OlePropertyGet("Cells", 2, 1); 
Range.OlePropertySet("RowHeight", 25);  
      在工作表最前面插入一行
Sheet1.OlePropertyGet("Rows", 1).OleProcedure("Insert"); 
      删除一行
ExcelApp.OlePropertyGet("Rows", 2).OleProcedure("Delete"); //将第2行删除      操作单元格★
      设置单元格字体
Sheet1.OlePropertyGet("Cells", 1, 1).OlePropertyGet("Font").OlePropertySet("Name", "隶书"); //字体
Sheet1.OlePropertyGet("Cells", 2, 3).OlePropertyGet("Font").OlePropertySet("size", 28);     //大小
      设置所选区域字体
Range.OlePropertyGet("Cells").OlePropertyGet("Font").OlePropertySet("Size", 28);
Range.OlePropertyGet("Cells").OlePropertyGet("Font").OlePropertySet("Color", RGB(0, 0, 255));
其中参数的设置:
Font   Name : "隶书"               //字体名称
Size : 12                   //字体大小
Color : RGB(*,*,*)           //颜色
Underline : true/false           //下划线
Italic: true/false           //斜体
      设置单元格格式为小数百分比
Sheet1.OlePropertyGet("Cells", 1, 1).OlePropertySet("NumberFormatLocal", "0.00%");
      设定单元格的垂直对齐方式
Range = ExcelApp.OlePropertyGet("Cells", 3, 4); // 1=靠上 2=居中 3=靠下对齐 4=两端对齐 5=分散对齐
Range.OlePropertySet("VerticalAlignment", 2);  
      设定单元格的文本为自动换行
Range = ExcelApp.OlePropertyGet("Cells", 3, 4);
Range.OlePropertySet("WrapText", true);
      单元格的合并★
Range = Sheet1.OlePropertyGet("Range", "A1:A2");          //A1A2单元格合并
String strRange = "A" + IntToStr(j) + ":" + "C" + IntToStr(j); //比如:A1:C5
Range1=Sheet1.OlePropertyGet("Range", strRange.c_str()); //可以用变量控制单元格合并
Range1.OleFunction("Merge", false);
      读写单元格★
      指定单元格赋值
String strValue = "abcdefg";
Sheet1.OlePropertyGet("Cells", 3, 6).OlePropertySet("Value", strValue.c_str());
Sheet1.OlePropertyGet("Cells", j, 1).OlePropertySet("Value", "总记录:" + String(j-6));
或者使用
Excel.Exec(PropertyGet("Cells")<<1<<3).Exec(PropertySet("Value")<<15);
      所选区域单元格赋值
Range.OlePropertyGet("Cells").OlePropertySet("Value", 10);     
      所选区域行赋值
Range.OlePropertyGet("Rows",1).OlePropertySet("Value", 1234);  
      工作表列赋值
Sheet1.OlePropertyGet("Columns",1).OlePropertySet("Value", 1234);
      读取取值语句:
String strValue = Sheet1.OlePropertyGet("Cells", 3, 5).OlePropertyGet("Value");
      窗口属性★
      显示属性
ExcelApp.OlePropertySet("Windowstate", 3);       //最大化显示
1---------xlNormal            //正常显示
2---------xlMinimized         //最小化显示
3---------xlMaximized         //最大化显示
      状态栏属性
ExcelApp.OlePropertySet("StatusBar", "您好,请您稍等。正在查询!");
ExcelApp.OlePropertySet("StatusBar", false);     //还原成默认值
      标题属性:
ExcelApp.OlePropertySet("Caption", "查询系统");
3、操作图表
      添加图表
Variant Chart;  
Chart = ExcelApp.Exec(PropertyGet("Charts")).Exec(Function("Add"));
ExcelApp.Exec(PropertySet("Visible") << true);
Chart.Exec(PropertySet("Type") << -4100);
      滚动图表
for(int nRotate=5; nRotate <= 180; nRotate += 5)
{
Chart.Exec(PropertySet("Rotation") << nRotate);
}
for (int nRotate = 175; nRotate >= 0; nRotate -= 5)
{
Chart.Exec(PropertySet("Rotation") << nRotate);
}
另外,为保证程序能正常运行,需要在程序中判断目标机器是否安装了Office;
try{
ExcelApp = Variant::CreateObject ("Excel.Application");
}catch(...){
ShowMessage("运行Excel出错,请确认安装了Office");
return;
}
 
#include "comobj.hpp"
//---------------------------------------------------------------------------
// 对指定Excel文件中的指定列进行排序
// strExcelFileName : excel文件名
// nCol : 指定的列号
// nSortStyle : 1:升序,2:降序
void SortExcelColumn(String strExcelFileName, int nCol, int nSortStyle)
{
Variant vExcelApp, vWorkbook, vRange;
vExcelApp = Variant::CreateObject("Excel.Application");
vExcelApp.OlePropertySet("Visible", false);
vExcelApp.OlePropertyGet("WorkBooks").OleProcedure("Open", strExcelFileName.c_str());
vWorkbook = vExcelApp.OlePropertyGet("ActiveWorkbook");
vExcelApp.OlePropertyGet("Columns", nCol).OleProcedure("Select");
vExcelApp.OlePropertyGet("ActiveSheet").OlePropertyGet("Cells", 1, nCol).OleProcedure("Select");
vRange =  vExcelApp.OlePropertyGet("Selection");
vRange.Exec(Function("Sort")<<vExcelApp.OlePropertyGet("Selection")<<nSortStyle);
vWorkbook.OleProcedure("Save");
vWorkbook.OleProcedure("Close");
vExcelApp.OleFunction("Quit");
vWorkbook = Unassigned;
vExcelApp = Unassigned;
ShowMessage("ok");
}
 
void __fastcall TForm1::Button1Click(TObject *Sender)
{
// C:/123/123.xls文件中第一个Sheet的第四列进行升序排序
SortExcelColumn("C: 用OLE操作Excel//123//123.xls", 4, 1);
}
//---------------------------------------------------------------------------

 
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值