如果值增加阈值,则读取XML的特定元素

时间:2017-06-28 05:56:55

标签: c# xml elements

我可以读取一个名为101.xml的XML文件,其中我可以读取名为light的元素,其中有两个值,例如1280和128,我可以显示它。但是我想只显示大于800的值。检查图像是否存在XML文件。

1

这就是我在Listbox中读取两个轻元素所做的:

阅读新文件:

        XmlTextReader Reader = new XmlTextReader(@"101.xml");
        XmlDocument doc = new XmlDocument();
        doc.Load(Reader);
        XPathNavigator nav = doc.CreateNavigator();

        //compile xpath 
        XPathExpression expr;
        expr = nav.Compile("/MotePacket/ParsedDataElement[Name='light']");
        XPathNodeIterator iterator = nav.Select(expr);

        //iterate node set and see values in list box
        listBox1.Items.Clear();
        try
        {
            while (iterator.MoveNext())
            {
                XPathNavigator nav2 = iterator.Current.Clone();
                listBox1.Items.Add("content and value: " + nav2);
            }
        }
        catch (Exception ex)
        {
            Console.WriteLine(ex.Message);
        }

2 个答案:

答案 0 :(得分:1)

这是非常糟糕的xml格式。建议改变。这是解析xml的代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Xml;
using System.Xml.Linq;

namespace ConsoleApplication1
{
    class Program
    {
        const string FILENAME = @"c:\temp\test.xml";
        static void Main(string[] args)
        {
            XDocument doc = XDocument.Load(FILENAME);

            List<XElement> parsedDataElements = doc.Descendants("ParsedDataElement").ToList();

            for (int i = 0; i < parsedDataElements.Count; i += 2)
            {
                DataElement newDataElement = new DataElement();
                DataElement.elements.Add(newDataElement);

                newDataElement.temperature = (double)parsedDataElements[i].Element("ConvertedValue");
                newDataElement.light = (int)parsedDataElements[i + 1].Element("ConvertedValue");
            }
        }
    }
    public class DataElement
    {
        public static List<DataElement> elements = new List<DataElement>();

        public double temperature { get; set; }
        public int light { get; set; }
    }
}

答案 1 :(得分:0)

正如我在问题评论中提到的,您可以将XDocument class与Linq查询一起使用来过滤xml数据。

请参阅:

XDocument xdoc = XDocument.Load(fullfilename);

var data = xdoc.Descendants("ParsedDataElement")
    .Where(x=>x.Element("Name").Value == "light" && Double.Parse(x.Element("ConvertedValue").Value)>800)
    .Select(x=> new
    {
        Name =  x.Element("Name").Value,
        ConvertedValue = Double.Parse(x.Element("ConvertedValue").Value)
    })
    .ToList();

现在,您可以使用foreach循环或设置DataSource将数据插入到ListBox对象中。

有关详细信息,请参阅:
Basic Queries (LINQ to XML) (C#)
How to: Bind a Windows Forms ComboBox or ListBox Control to Data

祝你好运!