首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >System.XML还是Regex.Replace?

System.XML还是Regex.Replace?
EN

Stack Overflow用户
提问于 2010-04-19 20:16:54
回答 4查看 162关注 0票数 3

我正在从Excel文件中的一组值生成大量XML文档。对于每个XML文档,唯一变化的是值。我认为生成这些文档的最好方法是创建一个"XML框架“(因为XML格式永远不会改变),然后插入像"&%blahNameblahTest”这样的符号,这样我就可以对每个值执行一个Regex.Replace。

我将把这个项目交给另一个开发人员,我想知道是否应该将项目转换为每次通过System.XML名称空间手动生成XML文件。

我看到的唯一好处是确保XML文档是有效的。

当前的方法将比该方法更具可读性,而且速度更快,因为我生成了大约1500个文档。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2010-04-19 20:20:36

我会坚持使用你现有的方法。

但是,我会添加一个对System.Linq.XML的引用,并对输出执行XElement.Parse(),以确保生成的文档能够正确解析。(您提到的System.Xml路由的一个优点!)

票数 1
EN

Stack Overflow用户

发布于 2010-04-19 20:21:59

您可以使用string.Format方法

代码语言:javascript
复制
string.Format(
@"
   <Parent attribute = \"{0}\">
      <Child>{1}</Child>
   </Parent>
",
"foo",
"bar"
);

这将导致

代码语言:javascript
复制
   <Parent attribute = "foo">
      <Child>bar</Child>
   </Parent>

您可以将其发送到任何流。

票数 0
EN

Stack Overflow用户

发布于 2010-04-19 20:48:43

通过将skelleton XML解析成XDocument并以LINQ to XML查询的形式执行替换,您可以两全其美。

也许可以像下面这样写一个扩展方法

代码语言:javascript
复制
public static void Replace(this XDocument haystack, String needle, String replacement)
{
    var query = haystack.Root
                        .DescendantsAndSelf()
                        .Where(xe => !xe.HasElements && xe.Value == needle);
    foreach (XElement item in query)
    {
        item.Value = replacement;
    }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2667255

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档