c++ builder OLE创建Excel表格

#include <vcl.h>
#pragma hdrstop


#include "Unit1.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm1 *Form1;
#define   PG   OlePropertyGet
#define   PS   OlePropertySet
#define   FN   OleFunction
#define   PR   OleProcedure
//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
        : TForm(Owner)
{
}
//---------------------------------------------------------------------------


void __fastcall TForm1::CreateExcel(ExcelPath)
{
        Variant vExcelApp;
        Variant WorkBook1;
        Variant Sheet1;
        Variant Range;
    try
    {
        vExcelApp = Variant::CreateObject("Excel.Application");
    }
    catch(...)
    {
        MessageBox(0, "启动 Excel 出错, 可能是没有安装Excel.",
                "提示", MB_OK | MB_ICONERROR);
        vExcelApp = Unassigned;


        return;
    }


   // 隐藏Excel界面
    vExcelApp.OlePropertySet("Visible", false);


    // 新建一个工作表
    vExcelApp.OlePropertyGet("Workbooks").OleFunction("Add", 1); // 工作表
    // 将剪贴板中的图像粘贴到Excel中
   // vExcelApp.OlePropertyGet("ActiveSheet").OleProcedure("Paste");
    Sheet1 = vExcelApp.PG("ActiveSheet");
    Sheet1.PG("Cells",1,1).PS("Value","表格");
 //   Sheet1.PG("Cells",1,1).PG("Font").PS("Name","宋体");
  //  Sheet1.PG("Cells",1,1).PG("Font").PS("size","12");


   // Sheet1.PG("Cells",1,1).PG("Font").PS("Bold",true);    //加粗
     Sheet1.PG("Cells",1,1).PS("NumberFormatLocal","000000"); //设置单元格格式为特殊

    vExcelApp.PG("Cells",1,1).PS("ColumnWidth",22);    //设置行宽
  //  vExcelApp.PG("Cells",1,1).PS("HorizontalAlignment",-4108);    //设置居中

    // 保存这个Excel文件
    vExcelApp.OlePropertyGet("ActiveWorkbook")
            .OleFunction("SaveAs", ExcelPath.c_str());


    // 退出Excel
       vExcelApp.OleFunction("Quit");
    vExcelApp = Unassigned;


}
//---------------------------------------------------------------------------

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值