注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

单眼皮男生

成长心路

 
 
 

日志

 
 
关于我

诚实开朗。

网易考拉推荐

开发小结  

2007-10-09 20:49:15|  分类: 心情 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

 经过一段时间开发,做了个小程序,里面用到自己好多以前在学校没有用过的控件,语法,结构,学到了很多东西。现小结如下:
一定要加头文件#include "comobj.hpp",

OLE操作
OlePropertySet(属性名,参数……);
OlePropertyGet(属性名,参数……);
OleFunction(函数名,参数……);
OleProcedure(过程名,参数……);
1、Excel中常用的对象是:Application,Workbooks,Worksheets等。
  
  ★创建应用对象★
       Variant ExcelApp;
       ExcelApp = Variant::CreateObject ("Excel.Application");
       或者
       ExcelApp = CreateOleObject ("Excel.Application");
  ★创建工作簿对象★
       Variant WorkBook1;
       WorkBook1 = ExcelApp.PG("ActiveWorkBook");
  ★创建工作表对象★
       Variant Sheet1;
       Sheet1 = WorkBook1.PG("ActiveSheet");
  ★创建区域对象★
       Variant Range;
       Range = Sheet1.PG("Range","A1:A10");    
       或者使用
       Excel.Exec(PropertyGet("Range")<<"A1:C1").Exec(Procedure("Select"));
2、常用的属性操作:
  
  ★使Excel程序不可见★
       ExcelApp.PS("Visible", (Variant)false);
        
  ★新建EXCEL文件★
    
    ◎ 新建系统模板的工作簿
       ExcelApp.PG("workbooks").FN("Add")      //默认工作簿
       ExcelApp.PG("workbooks").FN("Add", 1)   //单工作表
       ExcelApp.PG("workbooks").FN("Add", 2)   //图表  
       ExcelApp.PG("workbooks").FN("Add", 3)   //宏表 
       ExcelApp.PG("workbooks").FN("Add", 4)   //国际通用宏表
       ExcelApp.PG("workbooks").FN("Add", 5)   //与默认的相同
       ExcelApp.PG("workbooks").FN("Add", 6)   //工作簿且只有一个表
       或者使用ExcelApp的Exec方法
       Excel.Exec(PropertyGet("Workbooks")).Exec(Procedure("Add"));
    ◎ 新建自己创建的模板的工作簿
       ExcelApp.PG("workbooks").FN("Add", "C:\\Temp\\result.xlt");
        
  ★打开工作簿★
       ExcelApp.PG("workbooks").FN("open", "路径名.xls")  
        
  ★保存工作簿★
       WorkBook1.FN("Save");            //保存工作簿
       WorkBook1.FN("SaveAs", "文件名");//工作簿保存为,路径注意用"\\"
        
  ★退出EXCEL★
       ExcelApp.FN ("Quit");
       ExcelApp = Unassigned;
       或者
       ExcelApp.Exec(Procedure("Quit"));
        
  ★操作工作表★
    
    ◎ 选择选择工作表中第一个工作表
       Workbook1.PG("Sheets", 1).PR("Select");
       Sheet1 = Workbook1.PG("ActiveSheet");
    
    ◎ 重命名工作表
       Sheet1.PS("Name", "Sheet的新名字");
    
    ◎ 当前工作簿中的工作表总数
       int nSheetCount=Workbook1.PG("Sheets").PG("Count");       
        
  ★操作行和列★
   
    ◎ 获取当前工作表中有多少行和多少列:
       Sheet1.PG("UsedRange").PG("Columns").PG("Count"); //列数
       Sheet1.PG("UsedRange").PG("Rows").PG("Count");    //行数
    
    ◎ 设置列宽
       ExcelApp.PG("Columns", 1).PS("ColumnWidth", 22);
       或者
       Range = ExcelApp.PG("Cells", 1, 3);
       Range.PS("ColumnWidth", 22);      
    
    ◎ 设置行高
       ExcelApp.PG("Rows", 2).PS("RowHeight", 25);
       或者
       Range = ExcelApp.PG("Cells", 2, 1);        
       Range.PS("RowHeight", 25);     
    
    ◎ 在工作表最前面插入一行
       Sheet1.PG("Rows", 1).PR("Insert");        
    
    ◎ 删除一行
       ExcelApp.PG("Rows", 2).PR("Delete"); //将第2行删除
        
  ★操作单元格★
  
    ◎ 设置单元格字体
        Sheet1.PG("Cells", 1, 1).PG("Font").PS("Name", "隶书"); //字体
        Sheet1.PG("Cells", 2, 3).PG("Font").PS("size", 28);     //大小
        
    ◎ 设置所选区域字体
       Range.PG("Cells").PG("Font").PS("Size", 28);
       Range.PG("Cells").PG("Font").PS("Color", RGB(0, 0, 255));
       其中参数的设置:
       Font   Name : "隶书"               //字体名称
              Size : 12                   //字体大小
             Color : RGB(*,*,*)           //颜色
         Underline : true/false           //下划线
             Italic: true/false           //斜体
    
    ◎ 设置单元格格式为小数百分比
       Sheet1.PG("Cells", 1, 1).PS("NumberFormatLocal", "0.00%");
    ◎ 设定单元格的垂直对齐方式
       Range = ExcelApp.PG("Cells", 3, 4);
       // 1=靠上 2=居中 3=靠下对齐 4=两端对齐 5=分散对齐
       Range.PS("VerticalAlignment", 2);       
    
    ◎ 设定单元格的文本为自动换行
       Range = ExcelApp.PG("Cells", 3, 4);
       Range.PS("WrapText", true);
       
  ★单元格的合并★
    ◎ Range = Sheet1.PG("Range", "A1:A2");          //A1和A2单元格合并
       String strRange = "A" + IntToStr(j) + ":" + "C" + IntToStr(j); //比如:A1:C5
       Range1=Sheet1.PG("Range", strRange.c_str()); //可以用变量控制单元格合并
       Range1.FN("Merge", false);
        
  ★读写单元格★
    ◎ 指定单元格赋值
       String strValue = "abcdefg";
       Sheet1.PG("Cells", 3, 6).PS("Value", strValue.c_str()); 
       Sheet1.PG("Cells", j, 1).PS("Value", "总记录:" + String(j-6));
       或者使用
       Excel.Exec(PropertyGet("Cells")<<1<<3).Exec(PropertySet("Value")<<15);
    ◎ 所选区域单元格赋值
       Range.PG("Cells").PS("Value", 10);     
    ◎ 所选区域行赋值
       Range.PG("Rows",1).PS("Value", 1234);  
    ◎ 工作表列赋值
       Sheet1.PG("Columns",1).PS("Value", 1234); 
    ◎ 读取取值语句:
       String strValue = Sheet1.PG("Cells", 3, 5).PG("Value");
  ★窗口属性★
    
    ◎ 显示属性
       ExcelApp.PS("Windowstate", 3);       //最大化显示
              1---------xlNormal            //正常显示
              2---------xlMinimized         //最小化显示
              3---------xlMaximized         //最大化显示
    ◎ 状态栏属性
       ExcelApp.PS("StatusBar", "您好,请您稍等。正在查询!");
       ExcelApp.PS("StatusBar", false);     //还原成默认值
    ◎ 标题属性:
       ExcelApp.PS("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;

以上好明示是抄架啦。大家唔好见怪。
如果想设置其它EXECL,可以在EXECL里面宏控制录制宏然后再编辑宏,这样就可以获得具体属性。
还也以使用新的控件EHGRID。

装上之后,也要加一个头文件,使用一个函数调用就OK了。

不过用OLE速度会比较慢(别人说的),控件这个没具体做。

 

  评论这张
 
阅读(31)| 评论(1)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2018