繁体   English   中英

从XML值获取适当的变量

[英]Obtain appropriate variable from XML value

我有一些要从XML文件读取的值。 这些是在程序开始时声明的,如下所示:

static public int NumRecords;
static public int DBSize;
static public string SourceWorkbookPath;
static public string SourceSheetName;
static public string DestWorkbookPath;
static public string DestSheetName;

然后,我通过执行以下操作来读取它们的值:

private static void LoadXMLParameters()
    {
        XmlTextReader reader = new XmlTextReader(ParameterFilePath);

        while (reader.Read())
        {
            switch (reader.NodeType)
            {
                case XmlNodeType.Element: // The node is an element.        
                    reader.MoveToNextAttribute();

                    switch (reader.Value)
                    {
                        case "SourceWorkbookPath":
                            reader.MoveToNextAttribute();
                            SourceWorkbookPath = reader.Value;
                            break;
                        case "SourceSheetName":
                            reader.MoveToNextAttribute();
                            SourceSheetName = reader.Value;
                            break;
                        case "DestWorkbookPath":
                            reader.MoveToNextAttribute();
                            DestWorkbookPath = reader.Value;
                            break;
                        case "DestSheetName":
                            reader.MoveToNextAttribute();
                            DestSheetName = reader.Value;
                            break;
                        case "NumRecords":
                            reader.MoveToNextAttribute();
                            NumRecords = Int32.Parse(reader.Value);
                            break;
                        case "DBSize":
                            reader.MoveToNextAttribute();
                            DBSize = Int32.Parse(reader.Value);
                            break;
                    }
                    break;
            }
        }
    }

有没有一种方法可以动态地读取XML参数的值,从而不必为要添加的每个变量添加新的case

当然有可能-但我同意序列化一个类会更好。

我假设在此解决方案中,您正在寻找具有匹配名称的第一个属性:

class XmlAttributeParser
{
    IEnumerable<XAttribute> attributes;

    public XmlAttributeParser(string xml)
    {
        attributes = XElement.Parse(xml)
            .DescendantsAndSelf()
            .SelectMany(e => e.Attributes());
    }

    public T GetAttribute<T>(string name)
    {
        return (T)TypeDescriptor.GetConverter(typeof(T))
            .ConvertFromString(attributes.First(a => a.Name == name).Value);
    }
}

用过的:

string xml = "<Root><Foo Bar=\"123\" Baz=\"456\"/></Root>";
XmlAttributeParser parser = new XmlAttributeParser(xml);
int n = parser.GetAttribute<int>("Bar"); // 123

这种方法的缺点是必须将整个文件加载到内存中,并且每次需要查找变量时都必须搜索属性。

感谢@Ed Plunkett提供的评论,我最终反序列化XML。 首先,我添加了一个类来保存信息:

public class XMLInfo
{
    public int NumRecords;
    public int DBSize;
    public string SourceWorkbookPath;
    public string SourceSheetName;
    public string DestWorkbookPath;
    public string DestSheetName;
}

然后编写一个方法,将所有信息简单地转储到此类的实例中:

    private static XMLInfo LoadXMLParameters()
    {
        XMLInfo info = new XMLInfo();

        XmlSerializer serializer = new XmlSerializer(typeof(XMLInfo));

        using (Stream reader = new FileStream(ParameterFilePath, FileMode.Open))
        {
            return info = (XMLInfo)serializer.Deserialize(reader);
        }
    }

希望这对使用我最初方法的其他人有所帮助。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM