开源中国

我们不支持 IE 10 及以下版本浏览器

It appears you’re using an unsupported browser

为了获得更好的浏览体验,我们强烈建议您使用较新版本的 Chrome、 Firefox、 Safari 等,或者升级到最新版本的IE浏览器。 如果您使用的是 IE 11 或以上版本,请关闭“兼容性视图”。
自动化 OpenOffice 应用 - 技术翻译 - 开源中国社区

自动化 OpenOffice 应用 【已翻译100%】

oschina 推荐于 4年前 (共 2 段, 翻译完成于 01-06) 评论 3
收藏  
27
推荐标签: OpenOffice 待读

简介 

本文将介绍如何使用LibOpenOffice实施OpenOffice表格自动化。这个库被开发用来打开或编辑所有OpenOffice表格文档。

操作流程 

  1. 开始工作之前你需要下载LibOpenOffice库及示例项目,示例项目可以使用微软vs 2010或更高的版本打开。

  2. 下载Apache OpenOffice 3.4.1\4.0或更高版本,把它安装到电脑上。

  3. 解压下载的文档,打开LibOpenOffice_sample_project.sln

  4. 在打开的项目中你可以看到一个简单有按钮的表格,可以用它来创建Calc\Writer\Impress文件。

  5. 你也可以查看描述LibOpenOffice功能的帮助文件OOAPI.chm

Garfielt
 翻译得不错哦!

使用代码 

创建一个新的或打开一个已存在的OpenOffice表格文档:

OOAPI3 *t = new OOAPI3();
if( t )
{        
    if( t->isInstall() ) // check if OpenOffice is installed
    {
        if( t->connect2Calc("private:factory/scalc", 
            "localhost", "2083", false, "DEMO") ) 
        {
            // here your code to work with opened\created document
            // to open existing document you need to call
            // t->connect2Calc("file:///C:/test.xls", 
            //   "localhost", "2083", false, "DEMO")
        }
    }
}

在打开的OpenOffice表格文档中编辑文字:

if( t->connect2Calc("private:factory/scalc", 
  "localhost", "2083", false, "DEMO") )
{
    t->setSheet(0); // sets first sheet to edit
    t->setText(0,0,"Hello world!"); // sets "Hello world" string for A1 cell
}

在OpenOffice表格文档中使用样式:

if( t->connect2Calc("private:factory/scalc", 
  "localhost", "2083", false, "DEMO") ) 
{ 
    t->SetSheet(0); // sets first sheet to edit  
    t->setText(0,0,"244"); // sets "244" string for A1 cell
     t->setCellStyle(0,0,S_PERCENT); // sets "percent" style for A1 cell 
    t->setCellStyle(0,1,S_DATE_F);  // sets "date" style for A2 cell 
} 
//Note: all other styles you can see in OOAPI.chm help file.

保存当前文档:

if( t->connect2Calc("private:factory/scalc", 
  "localhost", "2083", false, "DEMO") ) 
{ 
    // some code to edit document
    t->export2XLS("file:///D:/test.xls"); // saving document to "D:\test.xls"
}

LibOpenOffice中也能使用文本,格式,样式,幻灯片,图片及其他功能。你可以在这里看到其他一些示例

结论 

LibOpenOffice是Apache OpenOffice自动化的一个强有力的工具。免费及专业团队的支持是它的重大优点。考虑到这个库的低开销,它的确是使用OpenOffice时自动化的一个好的解决方案。我希望这篇文章能在工作中帮到你。

Garfielt
 翻译得不错哦!
本文中的所有译文仅用于学习和交流目的,转载请务必注明文章译者、出处、和本文链接
我们的翻译工作遵照 CC 协议,如果我们的工作有侵犯到您的权益,请及时联系我们
评论(3)
Ctrl/CMD+Enter

原来是库,而且要钱!
too short! valueableless
我以为是宏呢
顶部