我有DateTable.需要在teplate文档中插入它而不是某些字符集.

我可以用这种方式替换文本到文本(很多missingObj以避免错误):

using Word = Microsoft.Office.Interop.Word;

    Word._Application application;
    Word._Document document;
    Object missingObj = System.Reflection.Missing.Value;
    Object trueObj = true;
    Object falSEObj = false;

    private void create_button1_Click(object sender,EventArgs e) {
            application = new Word.Application();
            Object templatePathObj;
            templatePathObj = "template.dot";  

            try {
                document = application.Documents.Add(ref  templatePathObj,ref missingObj,ref missingObj);
            }
            catch (Exception error) {
                document.Close(ref falSEObj,ref  missingObj,ref missingObj);
                application.Quit(ref missingObj,ref missingObj);
                document = null;
                application = null;
                throw error;
            }

            object strToFindobj = "%%mark%%";
            object replaceStrObj = "text to replace";
            Word.Range wordRange;
            object replaceTypeObj;
            replaceTypeObj = Word.WdReplace.wdReplaceAll;
            for (int i = 1; i <= document.Sections.Count; i++) {
                wordRange = document.Sections[i].Range;
                Word.Find wordFindobj = wordRange.Find;
                object[] wordFindParameters = new object[15] { strToFindobj,missingObj,replaceStrObj,replaceTypeObj,missingObj };
                wordFindobj.GetType().InvokeMember("Execute",BindingFlags.InvokeMethod,null,wordFindobj,wordFindParameters);
        }
        application.Visible = true;
    }

我必须改变所以这个代码将采用DataTable而不是strToFindobj?

在这个例子中,我替换Range中的东西,什么是文档的碎片,包括表格,格式等.

解决方法

lots of missingObj to avoid the bugs

目标.Net 4.0或更高版本支持COM调用的命名和可选参数,因此您不需要包含所有ref missingObj.请参阅此MSDN文章:Named and Optional Arguments – 此功能极大地方便了对COM接口(如Microsoft Office Automation API)的调用.

What do I have to change so I can search using a DataTable instead
of string variable strToFindobj?

您必须遍历DataTables Row和Cell替换Word文档中的DataTable单元格,例如:

foreach(var dr in dt.Rows)
{
  foreach (var cell in dr.ItemArray)
  {
    string strToFind = cell.ToString();
    string replaceStr = "replace old value";
    ReplaceTextInWord(@"C:\Temp\template.docx",strToFind,replaceStr);
  }
}

如果您发现太难使用DataTable并且想要一个更容易的列表(如字典):

var listofTextToReplace = new Dictionary<string,string>();
listofTextToReplace.Add("%%mark%%","text to replace");
foreach(var item in listofTextToReplace )
{
    string strToFind = item.Key;
    string replaceStr = item.Value;
    ReplaceTextInWord(@"C:\Temp\template.docx",replaceStr);
}

这是ReplaceTextInWord方法:

using Word = Microsoft.Office.Interop.Word;
Word._Application application;
Word._Document document;
Object missingObj = System.Reflection.Missing.Value;
Object trueObj = true;
Object falSEObj = false;

private void create_button1_Click(object sender,EventArgs e) {
   //ReplaceTextInWord("template.dot","find me","Found"); <-- Are you sure you want to replace in a Template?
   ReplaceTextInWord(@"C:\Temp\template.docx","%%mark%%","text to replace");  //I think you want a .DOC or DOCX file
}

private void ReplaceTextInWord(string wordDocFilePath,string strToFind,string replaceStr) {
    application = new Word.Application();
    try {
        //document = application.Documents.Add(ref templatePathObj,ref missingObj); 
        document = application.Documents.Open(wordDocFilePath);  //You need to open Word Documents,not add them,as per https://msdn.microsoft.com/en-us/library/tcyt0y1f.aspx
    }
    catch (Exception error) {
        document.Close(ref falSEObj,ref missingObj);
        application.Quit(ref missingObj,ref missingObj);
        document = null;
        application = null;
        throw error;
    }

    for (int i = 1; i <= document.Sections.Count; i++) {
    Word.Range wordRange = document.Sections[i].Range;
    Word.Find findobject = wordRange.Find;
    findobject.ClearFormatting();
    findobject.Text = strToFind;
    findobject.Replacement.ClearFormatting();
    findobject.Replacement.Text = replaceStr;

    object replaceAll = Word.WdReplace.wdReplaceAll;
    findobject.Execute(ref missing,ref missing,ref replaceAll,ref missing);
    }
    application.Visible = true;
}

参考MSDN:How to: Programmatically Search for and Replace Text in Documents

c# – 如何将表插入Word文档代替文本标记?的更多相关文章

  1. swift3.0-第一篇tableView

    最近这个月估计要一直设计新的项目天天开会苦不堪言啊~新的项目要用swift来写,从零开始还是很有乐趣的,简单总结了下table的使用,一起学习下吧。直接上代码了感谢观看,学以致用更感谢哦~

  2. jQuery中Datatables增加跳转到指定页功能

    本文给大家分享jquery中datatable增加跳转到指定页面功能以及jquery datatable中加入双击跳转功能的实例代码,需要的朋友参考下

  3. jQuery Datatable 多个查询条件自定义提交事件(推荐)

    这篇文章主要介绍了jQuery Datatable 多个查询条件自定义提交事件的相关资料,需要的朋友可以参考下

  4. jQuery插件DataTable使用方法详解(.Net平台)

    这篇文章主要为大家详细介绍了jQuery插件DataTable使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. angularJs中datatable实现代码

    本篇文章主要介绍了angularJs中datatable实现代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  6. 使用jquery DataTable和ajax向页面显示数据列表的方法

    今天小编就为大家分享一篇使用jquery DataTable和ajax向页面显示数据列表的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

  7. laravel yajra插件 datatable的使用详解

    这篇文章主要介绍了laravel yajra插件 datatable的使用详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  8. 使用jquery datatable和bootsrap创建表格实例代码

    这篇文章主要介绍了使用jquery-datatable和bootsrap创建表格的实例代码,需要的朋友可以参考下

  9. 从数据表导出excel时,在工作表中的2-3行添加徽标图像

    我到处搜索这个,但我没有找到任何解决方案。

  10. MySQL:使用终端从数据库中删除具有特定表前缀的表

    我试图使用带有特定表前缀的终端从PhpMyAdmin中删除数据库表。这些是我使用的代码格式,但似乎不起作用。mysql-BDatabaseName-uDatabaseUser-pDatabasePassword-e"SELECTCONCATFROMINFORMATION_SCHEMA.TABLESWHERETABLE_NAMELIKE'wordpress2_%'ANDTABLE_SCHEMA='DatabaseName';"非常感谢,非常感谢您的帮助。我希望我的PHPMyAdmin中开头前缀为“wordp

随机推荐

  1. c# – (wpf)Application.Current.Resources vs FindResource

    所以,我正在使用C#中的WPF创建一个GUI.它看起来像这样:它现在还没有完成.这两行是我尝试制作一种数据表,它们在XAML中是硬编码的.现在,我正在C#中实现添加新的水果按钮功能.我在XAML中有以下样式来控制行的背景图像应该是什么样子:因此,在代码中,我为每列col0,col1和col2创建一个图像,如果我使用以下代码,它添加了一个如下所示的新行:如你所见,它不太正确……为什么一个似乎忽略了一些属性而另一个没有?

  2. c# – 绑定DataGridTemplateColumn

    似乎我已经打了个墙,试图在DataGrid上使用DataTemplates.我想要做的是使用一个模板来显示每个单元格的两行文本.但是似乎无法以任何方式绑定列.以下代码希望显示我想做的事情.注意每个列的绑定:模板列没有这样的东西,因此,这个xaml不可能工作.我注定要将整个DataTemplate复制到每个列,只是对每个副本都有不同的约束?解决方法我不完全确定你想要做什么,但如果您需要获取整行的DataContext,可以使用RelativeSource绑定来移动视觉树.像这样:

  3. c# – 学习设计模式的资源

    最近我来到了这个设计模式的概念,并对此感到非常热情.你能建议一些帮助我深入设计模式的资源吗?

  4. c# – 是否有支持嵌入HTML页面的跨操作系统GUI框架?

    我想开发一个桌面应用程序来使用跨系统,是否有一个GUI框架,允许我为所有3个平台编写一次代码,并具有完全可脚本化的嵌入式Web组件?我需要它有一个API来在应用程序和网页之间进行交流.我知道C#,JavaScript和一些python.解决方法Qt有这样的事情QWebView.

  5. c# – 通过字符串在对象图中查找属性

    我试图使用任意字符串访问嵌套类结构的各个部分.给出以下(设计的)类:我想要从Person对象的一个实例的“PersonsAddress.HousePhone.Number”获取对象.目前我正在使用反思来做一些简单的递归查找,但是我希望有一些忍者有更好的想法.作为参考,这里是我开发的(crappy)方法:解决方法您可以简单地使用标准的.NETDataBinder.EvalMethod,像这样:

  6. c# – 文件下载后更新页面

    FamilyID=0a391abd-25c1-4fc0-919f-b21f31ab88b7&displaylang=en&pf=true它呈现该页面,然后使用以下元刷新标签来实际向用户提供要下载的文件:你可能需要在你的应用程序中做类似的事情.但是,如果您真的有兴趣在文件完全下载后执行某些操作,那么您的运气不佳,因为没有任何事件可以与浏览器进行通信.执行此操作的唯一方法是上传附件时使用的AJAXupload.

  7. c# – 如何在每个机器应用程序中实现单个实例?

    我必须限制我的.net4WPF应用程序,以便每台机器只能运行一次.请注意,我说每个机器,而不是每个会话.我使用一个简单的互斥体实现单实例应用程序,直到现在,但不幸的是,这样一个互斥是每个会话.有没有办法创建机器互连,还是有其他解决方案来实现每个机器应用程序的单个实例?

  8. c# – WCF和多个主机头

    我的雇主网站有多个主机名,都是同一个服务器,我们只是显示不同的皮肤来进行品牌宣传.不幸的是,在这种情况下,WCF似乎不能很好地工作.我试过overridingthedefaulthostwithacustomhostfactory.这不是一个可以接受的解决方案,因为它需要从所有主机工作,而不仅仅是1.我也看过thisblogpost,但是我无法让它工作,或者不是为了解决我的问题.我得到的错误是“这

  9. c# – ASP.NET MVC模型绑定与表单元素名称中的虚线

    我一直在搜索互联网,试图找到一种方式来容纳我的表单元素的破折号到ASP.NET的控制器在MVC2,3或甚至4中的默认模型绑定行为.作为一名前端开发人员,我更喜欢在我的CSS中使用camelCase或下划线进行破折号.在我的标记中,我想要做的是这样的:在控制器中,我会传入一个C#对象,看起来像这样:有没有办法通过一些正则表达式或其他行为来扩展Controller类来适应这种情况?我讨厌这样的事实,我必须这样做:甚至这个:思考?

  10. c# – 用户界面设计工具

    我正在寻找一个用户界面设计工具来显示文档中可能的GUI.我不能生成代码.我知道MicrosoftVisio提供了一个功能.但有什么办法吗?您使用哪种软件可视化GUI?

返回
顶部