使用 OpenOffice 进行邮件合并

2024-03-07

我目前正在尝试使用 C# 和 OpenOffice 进行邮件合并。

我的数据库中有一个 destanatary 列表。我希望这成为可能:

  • 用户编辑 OO 文档,将 “名称”“地址”“城市”等字段 和一些标准文本(例如:“你好Name你好吗 ?”,
  • 编辑样式等,
  • 然后转到我的应用程序,单击 “发送给数据库中的所有用户”。

然后程序循环遍历所有用户,并为每个用户将 OO 文档中的邮件合并字段替换为 DB 数据,通过邮件/打印/其他方式发送。

问题 :在 C# 中,我找不到任何方法用 DB 数据替换 OO 文档中的邮件合并字段,因为我找不到处理这些字段的属性/方法。

请大家帮帮我,年终奖就靠它了! (原文如此)

我发现的唯一提示是我似乎需要 UNO 库,但 C# 中似乎不存在它。


将 C# 与 OpenOffice 结合使用的一般帮助:

http://www.oooforum.org/forum/viewtopic.phtml?p=151606 http://www.oooforum.org/forum/viewtopic.phtml?p=151606 http://opendocument4all.com/content/view/68/47/ http://opendocument4all.com/content/view/68/47/

使用 OO 3.0,您需要引用 cli_*.dll 库,安装 OO 时会将它们放入 GAC。

初始化 OO 连接的示例代码:

 private static XMultiServiceFactory _multiServiceFactory;
 private static XComponentLoader _componentLoader;
 private static XFileIdentifierConverter _urlConverter;

 private static void Initialize()
 {
     XComponentContext localContext = uno.util.Bootstrap.bootstrap();
    _multiServiceFactory = (XMultiServiceFactory)localContext.getServiceManager();
    _componentLoader = (XComponentLoader)_multiServiceFactory.createInstance("com.sun.star.frame.Desktop");
    _urlConverter = (XFileIdentifierConverter)_multiServiceFactory.createInstance("com.sun.star.ucb.FileContentProvider");
 }

加载文档:

string url = _urlConverter.getFileURLFromSystemPath(Path.GetPathRoot(path), path);
XComponent xComponent = _componentLoader.loadComponentFromURL(url, "_blank", 0, new PropertyValue[] { MakePropertyValue("Hidden", new uno.Any(true))});
XTextDocument doc = (XTextDocument)xComponent;

where

 private static PropertyValue MakePropertyValue(string cName, Any uValue)
 {     
    PropertyValue oPropertyValue = new PropertyValue();
    if (!string.IsNullOrEmpty(cName))
       oPropertyValue.Name = cName;
    oPropertyValue.Value = uValue;
    return oPropertyValue;
 }

阅读更多有关我们可以做什么的信息 XTextDocumenthere http://api.openoffice.org/docs/common/ref/com/sun/star/text/XTextDocument.html.

也可以看看OpenOffice.org 开发人员指南 http://wiki.services.openoffice.org/wiki/Documentation/DevGuide/OpenOffice.org_Developers_Guide.

UPDATE。 另一个有用的链接:
http://blog.nkadesign.com/2008/net-working-with-openoffice-3/ http://blog.nkadesign.com/2008/net-working-with-openoffice-3/

希望这可以帮助

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

使用 OpenOffice 进行邮件合并 的相关文章

随机推荐

  • cx_Freeze 后 Paramiko 无法正常工作?

    所以我编写了这段代码 我使用 Paramiko 通过 SSH 连接到计算机 脚本正常工作 但是当我使用 cx Freeze 将其转换为 exe 时 程序在 self ssh load system host keys 处停止工作 所以我从脚
  • 将表示列表的字符串转换为实际的列表对象[重复]

    这个问题在这里已经有答案了 我有一个代表列表的字符串 22 33 36 41 46 49 56 72 85 92 95 98 107 118 120 123 124 126 127 130 149 157 161 171 174 177 1
  • flutter中的webview是否缓存网页?

    我想缓存在 flutter webview 中显示的网页 以便提高性能 无需重新加载页面 可以用吗 我可以实施吗 flutter inappwebview 前 flutter inappbrowser 有参数cacheEnabled默认为
  • 如何从 Google Places API 获取地点描述

    我正在尝试使用 Google 地点 API 来获取某些地点的信息 我有一个 来自谷歌搜索的示例 这是我试图找到的 我认为 Places API 文本搜索的 类型 字段将包含它 但该文本似乎不同 并且不在提供的选项列表中 如果有人可以提供一些
  • .Net 中的 Oracle 连接池

    我们有一个使用 Oracle 数据库的系统 有人问我系统是否使用连接池 但我不确定 我们正在使用Oracle DataAccess Client OracleConnection 在阅读该主题时 我发现连接字符串中的连接池设置为 true
  • 在vagrant box上创建虚拟主机

    我正在尝试设置一个基于 Chef 提供的 vagrant 的开发环境 我使用 Apache 使用 Chef 创建了一个环境 并且可以通过端口转发从我的主机访问 Web 服务器 我想让我的流浪盒包含多个虚拟主机 并且通过共享文件夹 我将定义不
  • spring-boot oauth2 拆分授权服务器和资源服务器

    我试图在 spring boot 中将资源服务器与授权服务器分开 我有两个单独运行的不同应用程序 在授权服务器中 我可以从 oauth token 获取不记名令牌 但是当我尝试访问资源 在标头中发送令牌 时 我收到无效令牌错误 我的目的是使
  • AZURE Active Directory - 服务主体和企业应用程序之间有什么区别?

    我经常对 Azure AD 中的三个主题感到困惑 服务负责人 企业应用 应用程序注册 有什么不同 我可以轻松进入 应用程序注册 并注册一个 应用程序 而该 应用程序 甚至不需要存在 它所需要的只是一个 URL 也可以是完全随机的 然后 此应
  • 如何对命令行参数进行单元测试?

    我正在尝试向 Python 提供命令行参数unittest并面临一些问题 我在互联网上搜索并找到了一种提供参数的方法 unittest main argv myArg 问题是这对于单个命令行参数工作正常 但对于多个参数则失败 unittes
  • 为 Heroku 静态编译 pdftk。需要将PDF分割成单页文件

    所以我们使用 heroku 来托管我们的 Rails 应用程序 我们已经搬到雪松堆了 该堆栈没有安装 pdftk 库 我联系了支持人员 并被告知为 amd64 ubuntu 静态编译它并将其包含在我的应用程序中 事实证明这比我想象的要困难
  • 工厂方法更适合框架,抽象工厂更适合库吗?

    抽象工厂和工厂方法模式都是创建型设计模式 解决了不同场景下的对象创建问题 根据 GOF工厂方法 pattern 定义一个用于创建对象的接口 但让子类决定实例化哪个类 工厂方法让类将实例化推迟到子类 我的理解 动机Client是获取执行的工厂
  • 将 Excel 导入到 DataTable 字符串为空

    要将 Excel 导入数据表 我使用简单的代码 string connectionString string Format Provider Microsoft ACE OLEDB 12 0 data source 0 Extended P
  • React:更新列表中的一项而不重新创建所有项目

    假设我有一个包含 1000 个项目的列表 我用 React 渲染它 如下所示 class Parent extends React Component render this state list is a list of 1000 ite
  • 将参数传递到 os.system

    我需要通过 python 执行以下命令 rtl2gds 是一个读取 2 个参数的工具 文件路径和模块名称 rtl2gds rtl home users name file v rtl top module name syn 我正在通过 ar
  • scipy ode 将函数集内的 set_f_params 更新为 set_solout

    将 ode 与 scipy 集成时 ode 接受参数多于 t 和 y 的函数 例如 def fun t y param1 param2 这些参数的值可以使用设置set f params method 然而 当同时使用set solout方法
  • 保持叉子最新的最有效方法

    我可以想出几种方法来保持分叉最新 git pull apply changes using a script pull automatically merges git pull 合并 可能有冲突 git fetch https stack
  • 共享主机上的 Laravel file_put_contents 错误

    我创建了 Laravel 应用程序 并在共享主机上上传 其显示错误 file put contents D xampp htdocs Laravel storage framework sessions FlEPsHNW7Rggfb9wvD
  • 使用 stdout 和 stderr 禁用缓冲是否安全?

    有时我们会以这种方式在代码中添加一些调试打印 printf successfully reached at debug point 1 n some code is here printf successfully reached at d
  • 播放无法在编码 UI 中找到具有给定搜索属性的控件

    我是编码 UI 测试的新手 所以这里有一个 简单 问题 尝试浏览菜单选项 我记录了操作并尝试播放 我收到以下消息 The playback failed to find the control with the given search p
  • 使用 OpenOffice 进行邮件合并

    我目前正在尝试使用 C 和 OpenOffice 进行邮件合并 我的数据库中有一个 destanatary 列表 我希望这成为可能 用户编辑 OO 文档 将 名称 地址 城市 等字段 和一些标准文本 例如 你好Name你好吗 编辑样式等 然