13

我有问题:

我必须将类序列化为 XML 文件。但是必须使用相同的名称命名两个属性:

所需的xml:

<?xml version="1.0"?>
<Test>
  <HeaderText>
    <Tag1>AAA</Tag1>
  </HeaderText>
  <HeaderText>
    <Tag2>BBB</Tag2>
  </HeaderText>
</Test>

我不需要将它反序列化回对象。

代码:

public class Header1
{
    [XmlElement("Tag1")]
    public String Tag1 { get; set; }
}

public class Header2
{
    [XmlElement("Tag2")]
    public String Tag2 { get; set; }
}

public class Test
{
    [XmlElement("HeaderText")]
    public Header1 Header1 { get; set; }

    [XmlElement("HeaderText")]
    public Header2 Header2 { get; set; }
}

var doc = new Test
{
    Header1 = new Header1 { Tag1 = "AAA" },
    Header2 = new Header2 { Tag2 = "BBB" }
};

var xml = new XmlSerializer(typeof(Test));
using (var fs = new FileStream("test.xml", FileMode.Create))
{
    xml.Serialize(fs, doc);
}

此代码不起作用。

命名空间 '' 中的 XML 元素 'HeaderText' 已存在于当前范围内。使用 XML 属性为元素指定另一个 XML 名称或命名空间。

我能做些什么?

真实世界的例子:

  <Product>
    <RecordReference>1-15991</RecordReference>
    <MainSubject>
      <MainSubjectSchemeIdentifier>66</MainSubjectSchemeIdentifier>
      <SubjectCode>2</SubjectCode>
    </MainSubject>
    <MainSubject>
      <MainSubjectSchemeIdentifier>20</MainSubjectSchemeIdentifier>
      <SubjectHeadingText>Venäläisiä kirjoja: uskonto, teosofia, mystiikka</SubjectHeadingText>
    </MainSubject>
</Product>
4

2 回答 2

11

使用数组:

public class Test
{
    [XmlElement("HeaderText")]
    public string[] HeaderText { get; set; }
}

接着:

var doc = new Test
{
    HeaderText = new[] { "AAA", "BBB" }
};
var xml = new XmlSerializer(typeof(Test));
using (var fs = new FileStream("test.xml", FileMode.Create))
{
    xml.Serialize(fs, doc);
}

也适用于List<string>.


更新:

使用复杂对象定义模型:

public class Header
{
    public string Tag { get; set; }
}

然后你就有了这个模型的集合:

public class Test
{
    [XmlElement("HeaderText")]
    public Header[] HeaderText { get; set; }
}

然后你序列化:

var doc = new Test
{
    HeaderText = new[] 
    { 
        new Header { Tag = "AAA" }, 
        new Header { Tag = "BBB" }
    }
};
var xml = new XmlSerializer(typeof(Test));
using (var fs = new FileStream("test.xml", FileMode.Create))
{
    xml.Serialize(fs, doc);
}
于 2012-07-02T09:06:47.157 回答
8

您可以告诉序列化程序忽略您当前的属性,并添加一个新属性以进行序列化:

public class Test
{
    [XmlIgnore]
    public String Header1 { get; set; }

    [XmlIgnore]
    public String Header2 { get; set; }

    [XmlElement("HeaderText")]
    public String[] HeaderText
    {
        get{  return new[]{Header1,Header2};   }
        set{  if(value.Length == 2) { Header1 = value[0]; Header2 = value[1];} }
    }
}

现场示例:http ://rextester.com/YVEF64085

于 2012-07-02T09:13:01.703 回答