将字符串索引器添加到XmlSerializer

时间:2015-08-19 15:02:05

标签: c# xml-deserialization

我有一个我无法更改的XML源代码,我想使用XmlSerializer对其进行反序列化。

我可以做得很好但是有一些自定义类数组我想通过String访问数组而不是整数。

我知道我可以使用

public ClassName this[string index] 

但我无法确定将其添加到我的班级的位置。

我希望能够致电

Object.Transaction["TransactionTypeName"] 

而不是

Object.Transaction[0]

这是该课程的精简版。

public partial class Configuration
{
    private ConfigurationTransaction[] transactionsField;

    [System.Xml.Serialization.XmlArrayItemAttribute("Transaction", IsNullable = false)]
    public List<ConfigurationTransaction> Transactions
    {
        get
        {
            return this.transactionsField;
        }
        set
        {
            this.transactionsField = value;
        }
    }
}

public partial class ConfigurationTransaction
{
    private string typeField;

    [System.Xml.Serialization.XmlAttributeAttribute()]
    public string type
    {
        get
        {
            return this.typeField;
        }
        set
        {
            this.typeField = value;
        }
    }

}

2 个答案:

答案 0 :(得分:0)

带有索引器的类的简化示例代码。 虽然我们需要保存访问索引器的值,但还是要创建额外的类。

public class Configuration
{
    public ConfigurationTransaction this[string transactionName]
    {
        get
        {
            return Transactions.First(tran => tran.TransactionName == transactionName).ConfigurationTransaction;
        }
        set
        {
            int index = Transactions.FindIndex(tran => tran.TransactionName == transactionName);
            if (index >= 0)
                Transactions[index] = new PairHelper { TransactionName = transactionName, ConfigurationTransaction = value };
            else
                Transactions.Add(new PairHelper { TransactionName = transactionName, ConfigurationTransaction = value });
        }
    }
    [EditorBrowsable(EditorBrowsableState.Never)]
    public List<PairHelper> Transactions { get; set; }
}

public class ConfigurationTransaction
{
    [XmlAttribute()]
    public string Type { get; set; }
}

public class PairHelper
{
    public string TransactionName { get; set; }
    public ConfigurationTransaction ConfigurationTransaction { get; set; }
}

这是工作:

Configuration conf = new Configuration();
conf.Transactions = new List<PairHelper>();
conf["fooTran"] = new ConfigurationTransaction { Type = "foo" };
conf["barTran"] = new ConfigurationTransaction { Type = "bar" };

var xs = new XmlSerializer(typeof(Configuration));
using (var fs = new FileStream("test.txt", FileMode.Create))
{
    xs.Serialize(fs, conf);
}

Configuration conf2;
using (var fs = new FileStream("test.txt", FileMode.Open))
{
    conf2 = (Configuration)xs.Deserialize(fs);
}

foreach (var tran in conf2.Transactions)
    Console.WriteLine(tran.TransactionName + " : " + tran.ConfigurationTransaction);
Console.WriteLine(conf2["fooTran"].Type);
Console.WriteLine(conf2["barTran"].Type);

XML将如下所示:

<?xml version="1.0"?>
<Configuration xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
  <Transactions>
    <PairHelper>
      <TransactionName>fooTran</TransactionName>
      <ConfigurationTransaction Type="foo" />
    </PairHelper>
    <PairHelper>
      <TransactionName>barTran</TransactionName>
      <ConfigurationTransaction Type="bar" />
    </PairHelper>
  </Transactions>
</Configuration>

答案 1 :(得分:0)

我能够将其添加到Configuration类中。

public ConfigurationTransaction this[String index]
{
    get
    {
        foreach (var item in Transactions)
        {
            if (item.type.ToLower().Trim() == index.ToLower().Trim())
            {
                return item;
            }
        }
        return null;
    }
}    

并称之为

Object["TransactionTypeName"] 

我认为无论如何我做了什么,我最终手动将所有数据导入SQL数据库并创建了一个Entity Framework类来访问它并对XML解决方案进行了描述。