5

我想要做的是在 xml 中找到占位符并替换它们。Jinja2 在 Python 中做到了这一点,但我正在 C# 中寻找类似的东西。基本上我想要做的是采取这个:

<?xml version="1.0" encoding="utf-8"?>
<Data>
  <Title>{{ myTitle }}</Title>
  <Comp>
  {% for item in compItems %}  <CompItem>
      <CompItemConfig>{{ item.config }}</CompItemConfig>
    </CompItem>
  </Comp>
{% endfor %}
</Data>

并以编程方式将其变为:

<?xml version="1.0" encoding="utf-8"?>
<Data>
  <Title>Brown Fox</Title>
  <Comp>
    <CompItem>
      <CompItemConfig>QUICK</CompItemConfig>
    </CompItem>
    <CompItem>
      <CompItemConfig>JUMPS</CompItemConfig>
    </CompItem>
    <CompItem>
      <CompItemConfig>NOT LAZY</CompItemConfig>
    </CompItem>
  </Comp>
</Data>

作为参考,我认为它应该如何工作的一个简单示例是:

Dictionary<string, string> myDictionary = new Dictionary<string, string>();
myDictionary.Add("myTitle", "Brown Fox");
myDictionary.Add("compItem", "QUICK");
myDictionary.Add("compItem", "JUMPS");
myDictionary.Add("compItem", "NOT LAZY");
FillTemplate("C:\myTemplate.xml", myDictionary);

任何帮助都会很棒。谢谢!

4

2 回答 2

8

我知道它已经晚了,但我真的需要你在这里要求的东西,所以我做了这个https://github.com/beto-rodriguez/Templator标记有点不同但它应该工作相同,如果你是熟悉 angularJs 使用它不会有任何问题。

我采用这种方法是因为我需要与更多用户共享模板,您生成一个模板并可以共享它以打印标签(在我的情况下)

这是一个例子

C#

var compiler = new Compiler()
            .AddKey("name", "Excel")
            .AddKey("width", 100)
            .AddKey("height", 500)
            .AddKey("bounds", new[] {10, 0, 10, 0})
            .AddKey("elements", new []
            {
                new { name = "John", age= 10 },
                new { name = "Maria", age= 57 },
                new { name = "Mark", age= 23 },
                new { name = "Edit", age= 82 },
                new { name = "Susan", age= 37 }
            });

var compiled = compiler.CompileXml(@"C:\...\myXml.xml")

XLM 源

<document>
  <name>my name is {{name}}</name>
  <width>{{width}}</width>
  <height>{{height}}</height>
  <area>{{width*height}}</area>
  <padding>
    <bound sxRepeat="bound in bounds">{{bound}}</bound>
  </padding>
  <content>
    <element sxRepeat="element in elements" sxIf="element.age > 25">
      <name>{{element.name}}</name>
      <age>{{element.age}}</age>
    </element>
  </content> 
</document>

编译

<document>
  <name>my name is Excel</name>
  <width>100</width>
  <height>500</height>
  <area>50000</area>
  <padding>
    <bound>10</bound>
    <bound>0</bound>
    <bound>10</bound>
    <bound>0</bound>
  </padding>
  <content>
    <element>
      <name>Maria</name>
      <age>57</age>
    </element>
    <element>
      <name>Edit</name>
      <age>82</age>
    </element>
    <element>
      <name>Susan</name>
      <age>37</age>
    </element>
  </content>
</document>

你也可以从 Nuget 安装它:

Install-Package SuperXml
于 2015-08-03T02:11:53.033 回答
5

C# 具有用于 XML 序列化和反序列化的内置工具:https ://msdn.microsoft.com/en-us/library/szzyf24s(v=vs.110).aspx

您只需声明:

[XmlType("Data")]
public class Data {

  [XmlElement("Title")]
  public string Title {get; set; }

  [XmlArray("Comp")]
  [XmlArrayItem("CompItem")]
  public List<CompItem> Comp {get; set; }

}

和:

[XmlType("Foo")]
public class CompItem {

  [XmlElement("CompItemConfig")]
  public string Config {get; set; }

}

然后,您可以通过简单的 C# 代码构造一个Data-object。最后,您可以使用以下代码将其转换为 XML 文件:

Data data = new Data(...);//create Data object
System.Xml.Serialization.XmlSerializer xmls = new System.Xml.Serialization.XmlSerializer(typeof(Data));
System.IO.StreamWriter writer= new System.IO.StreamWriter(@"C:\myTemplate.xml");
writer.Serialize(file, data);
writer.Close();

更多信息可以在这里找到:http: //msdn.microsoft.com/en-us/library/vstudio/ms172873.aspx

于 2013-09-10T04:20:07.673 回答