[英]Accessing XML data from C#
我正在努力從C#訪問XML文件中存儲的數據。 我讀了很多帖子-最近的帖子在這里 -但仍然無法正常工作。
xml節點如下所示:
<Prop Name='StartTime' Type='Number' Flags='0x0'>
<Value>171.8032865</Value>
</Prop>
我需要知道名為“ StartTime”的屬性的值是什么
編輯:上面的節點是xml文檔中眾多節點之一。 它嵌套在其他節點之間。 我需要找到名稱為“ StartTime”的屬性的所有值。
我使用XAML。
EDIT2:我認為如果顯示更大的xml塊(必須從中獲取數據)會更好。 看來Kaz的解決方案是最接近所需解決方案的解決方案,但是如果我加載整個xml,它就會失敗。
XML檔案:
<Prop Type='TEResult' Flags='0x0'>
<Prop Name='TS' Type='Obj' Flags='0x0'>
<Prop Name='SequenceCall' Type='Obj' Flags='0x0'>
<Prop Name='ResultList' Type='Array' LBound='[0]' HBound='[3]' ElementType='Obj' Flags='0x0'>
<ArrayElementPrototype Type='TEResult' Flags='0x0'>
</ArrayElementPrototype>
<Value ID='[0]'>
<Prop Type='TEResult' Flags='0x0'>
<Prop Name='Error' Type='Obj' TypeName='Error' Flags='0x400000'>
<Prop Name='Code' Type='Number' Flags='0x400000'>
<Value>0</Value>
</Prop>
<Prop Name='Msg' Type='String' Flags='0x400000'>
<Value></Value>
</Prop>
<Prop Name='Occurred' Type='Boolean' Flags='0x400000'>
<Value>False</Value>
</Prop>
</Prop>
<Prop Name='Status' Type='String' Flags='0x400000'>
<Value>Failed</Value>
</Prop>
<Prop Name='Numeric' Type='Number' Flags='0x2400'>
<Value>0</Value>
</Prop>
<Prop Name='ReportText' Type='String' Flags='0x400000'>
<Value></Value>
</Prop>
<Prop Name='Common' Type='Obj' TypeName='CommonResults' Flags='0x0'>
<Prop Name='IncludeInReport' Type='Boolean' Flags='0x0'>
<Value>True</Value>
</Prop>
</Prop>
<Prop Name='TS' Type='Obj' Flags='0x0'>
<Prop Name='StartTime' Type='Number' Flags='0x0'>
<Value>171.8032865</Value>
</Prop>
<Prop Name='TotalTime' Type='Number' Flags='0x0'>
<Value>0.0005158</Value>
</Prop>
<Prop Name='Index' Type='Number' Flags='0x0'>
<Value>0</Value>
</Prop>
<Prop Name='StepName' Type='String' Flags='0x0'>
<Value>Test 1</Value>
</Prop>
<Prop Name='StepGroup' Type='String' Flags='0x0'>
<Value>Main</Value>
</Prop>
<Prop Name='StepId' Type='String' Flags='0x0'>
<Value>ID#:TbZA+59stkivP1pqe//sUB</Value>
</Prop>
<Prop Name='Id' Type='Number' Flags='0x0'>
<Value>5</Value>
</Prop>
<Prop Name='StepType' Type='String' Flags='0x0'>
<Value>NumericLimitTest</Value>
</Prop>
<Prop Name='StepCausedSequenceFailure' Type='Boolean' Flags='0x0'>
<Value>True</Value>
</Prop>
<Prop Name='BlockLevel' Type='Number' Flags='0x0'>
<Value>0</Value>
</Prop>
</Prop>
<Prop Name='Limits' Type='Obj' Flags='0x3000'>
<Prop Name='Low' Type='Number' Flags='0x0'>
<Value>9</Value>
</Prop>
<Prop Name='High' Type='Number' Flags='0x0'>
<Value>11</Value>
</Prop>
</Prop>
<Prop Name='Comp' Type='String' Flags='0x3000'>
<Value>GELE</Value>
</Prop>
</Prop>
</Value>
<Value ID='[1]'>
<Prop Type='TEResult' Flags='0x0'>
<Prop Name='Error' Type='Obj' TypeName='Error' Flags='0x400000'>
<Prop Name='Code' Type='Number' Flags='0x400000'>
<Value>0</Value>
</Prop>
<Prop Name='Msg' Type='String' Flags='0x400000'>
<Value></Value>
</Prop>
<Prop Name='Occurred' Type='Boolean' Flags='0x400000'>
<Value>False</Value>
</Prop>
</Prop>
<Prop Name='Status' Type='String' Flags='0x400000'>
<Value>Failed</Value>
</Prop>
<Prop Name='Numeric' Type='Number' Flags='0x2400'>
<Value>0</Value>
</Prop>
<Prop Name='ReportText' Type='String' Flags='0x400000'>
<Value></Value>
</Prop>
<Prop Name='Common' Type='Obj' TypeName='CommonResults' Flags='0x0'>
<Prop Name='IncludeInReport' Type='Boolean' Flags='0x0'>
<Value>True</Value>
</Prop>
</Prop>
<Prop Name='TS' Type='Obj' Flags='0x0'>
<Prop Name='StartTime' Type='Number' Flags='0x0'>
<Value>171.8135159</Value>
</Prop>
<Prop Name='TotalTime' Type='Number' Flags='0x0'>
<Value>0.0000802</Value>
</Prop>
<Prop Name='Index' Type='Number' Flags='0x0'>
<Value>1</Value>
</Prop>
<Prop Name='StepName' Type='String' Flags='0x0'>
<Value>Test 2</Value>
</Prop>
<Prop Name='StepGroup' Type='String' Flags='0x0'>
<Value>Main</Value>
</Prop>
<Prop Name='StepId' Type='String' Flags='0x0'>
<Value>ID#:7RheSM0MDEGTAnRrrfGNcB</Value>
</Prop>
<Prop Name='Id' Type='Number' Flags='0x0'>
<Value>6</Value>
</Prop>
<Prop Name='StepType' Type='String' Flags='0x0'>
<Value>NumericLimitTest</Value>
</Prop>
<Prop Name='StepCausedSequenceFailure' Type='Boolean' Flags='0x0'>
<Value>False</Value>
</Prop>
<Prop Name='BlockLevel' Type='Number' Flags='0x0'>
<Value>0</Value>
</Prop>
</Prop>
<Prop Name='Limits' Type='Obj' Flags='0x3000'>
<Prop Name='Low' Type='Number' Flags='0x0'>
<Value>9</Value>
</Prop>
<Prop Name='High' Type='Number' Flags='0x0'>
<Value>11</Value>
</Prop>
</Prop>
<Prop Name='Comp' Type='String' Flags='0x3000'>
<Value>GELE</Value>
</Prop>
</Prop>
</Value>
<Value ID='[2]'>
<Prop Type='TEResult' Flags='0x0'>
<Prop Name='Error' Type='Obj' TypeName='Error' Flags='0x400000'>
<Prop Name='Code' Type='Number' Flags='0x400000'>
<Value>0</Value>
</Prop>
<Prop Name='Msg' Type='String' Flags='0x400000'>
<Value></Value>
</Prop>
<Prop Name='Occurred' Type='Boolean' Flags='0x400000'>
<Value>False</Value>
</Prop>
</Prop>
<Prop Name='Status' Type='String' Flags='0x400000'>
<Value>Failed</Value>
</Prop>
<Prop Name='Numeric' Type='Number' Flags='0x2400'>
<Value>0</Value>
</Prop>
<Prop Name='ReportText' Type='String' Flags='0x400000'>
<Value></Value>
</Prop>
<Prop Name='Common' Type='Obj' TypeName='CommonResults' Flags='0x0'>
<Prop Name='IncludeInReport' Type='Boolean' Flags='0x0'>
<Value>True</Value>
</Prop>
</Prop>
<Prop Name='TS' Type='Obj' Flags='0x0'>
<Prop Name='StartTime' Type='Number' Flags='0x0'>
<Value>171.8240739</Value>
</Prop>
<Prop Name='TotalTime' Type='Number' Flags='0x0'>
<Value>0.000081</Value>
</Prop>
<Prop Name='Index' Type='Number' Flags='0x0'>
<Value>2</Value>
</Prop>
<Prop Name='StepName' Type='String' Flags='0x0'>
<Value>Test 3</Value>
</Prop>
<Prop Name='StepGroup' Type='String' Flags='0x0'>
<Value>Main</Value>
</Prop>
<Prop Name='StepId' Type='String' Flags='0x0'>
<Value>ID#:pWFWDejvo0GThcOYVssHBA</Value>
</Prop>
<Prop Name='Id' Type='Number' Flags='0x0'>
<Value>7</Value>
</Prop>
<Prop Name='StepType' Type='String' Flags='0x0'>
<Value>NumericLimitTest</Value>
</Prop>
<Prop Name='StepCausedSequenceFailure' Type='Boolean' Flags='0x0'>
<Value>False</Value>
</Prop>
<Prop Name='BlockLevel' Type='Number' Flags='0x0'>
<Value>0</Value>
</Prop>
</Prop>
<Prop Name='Limits' Type='Obj' Flags='0x3000'>
<Prop Name='Low' Type='Number' Flags='0x0'>
<Value>9</Value>
</Prop>
<Prop Name='High' Type='Number' Flags='0x0'>
<Value>11</Value>
</Prop>
</Prop>
<Prop Name='Comp' Type='String' Flags='0x3000'>
<Value>GELE</Value>
</Prop>
</Prop>
</Value>
<Value ID='[3]'>
<Prop Type='TEResult' Flags='0x0'>
<Prop Name='Error' Type='Obj' TypeName='Error' Flags='0x400000'>
<Prop Name='Code' Type='Number' Flags='0x400000'>
<Value>0</Value>
</Prop>
<Prop Name='Msg' Type='String' Flags='0x400000'>
<Value></Value>
</Prop>
<Prop Name='Occurred' Type='Boolean' Flags='0x400000'>
<Value>False</Value>
</Prop>
</Prop>
<Prop Name='Status' Type='String' Flags='0x400000'>
<Value>Failed</Value>
</Prop>
<Prop Name='Numeric' Type='Number' Flags='0x2400'>
<Value>0</Value>
</Prop>
<Prop Name='ReportText' Type='String' Flags='0x400000'>
<Value></Value>
</Prop>
<Prop Name='Common' Type='Obj' TypeName='CommonResults' Flags='0x0'>
<Prop Name='IncludeInReport' Type='Boolean' Flags='0x0'>
<Value>True</Value>
</Prop>
</Prop>
<Prop Name='TS' Type='Obj' Flags='0x0'>
<Prop Name='StartTime' Type='Number' Flags='0x0'>
<Value>171.8270851</Value>
</Prop>
<Prop Name='TotalTime' Type='Number' Flags='0x0'>
<Value>0.0001041</Value>
</Prop>
<Prop Name='Index' Type='Number' Flags='0x0'>
<Value>3</Value>
</Prop>
<Prop Name='StepName' Type='String' Flags='0x0'>
<Value>Test 4</Value>
</Prop>
<Prop Name='StepGroup' Type='String' Flags='0x0'>
<Value>Main</Value>
</Prop>
<Prop Name='StepId' Type='String' Flags='0x0'>
<Value>ID#:w+ziJ/u2bkWz+F3kWa4mpC</Value>
</Prop>
<Prop Name='Id' Type='Number' Flags='0x0'>
<Value>8</Value>
</Prop>
<Prop Name='StepType' Type='String' Flags='0x0'>
<Value>NumericLimitTest</Value>
</Prop>
<Prop Name='StepCausedSequenceFailure' Type='Boolean' Flags='0x0'>
<Value>False</Value>
</Prop>
<Prop Name='BlockLevel' Type='Number' Flags='0x0'>
<Value>0</Value>
</Prop>
</Prop>
<Prop Name='Limits' Type='Obj' Flags='0x3000'>
<Prop Name='Low' Type='Number' Flags='0x0'>
<Value>9</Value>
</Prop>
<Prop Name='High' Type='Number' Flags='0x0'>
<Value>11</Value>
</Prop>
</Prop>
<Prop Name='Comp' Type='String' Flags='0x3000'>
<Value>GELE</Value>
</Prop>
</Prop>
</Value>
</Prop>
<Prop Name='SequenceFile' Type='String' Flags='0x0'>
<Value>C:\Users\Public\Documents\National Instruments\TestStand 2010 SP1\Sequence File 16.seq</Value>
</Prop>
<Prop Name='Sequence' Type='String' Flags='0x0'>
<Value>MainSequence</Value>
</Prop>
<Prop Name='Status' Type='String' Flags='0x0'>
<Value>Failed</Value>
</Prop>
</Prop>
<Prop Name='StartTime' Type='Number' Flags='0x0'>
<Value>171.6948629</Value>
</Prop>
<Prop Name='TotalTime' Type='Number' Flags='0x0'>
<Value>0.1359434</Value>
</Prop>
<Prop Name='ModuleTime' Type='Number' Flags='0x0'>
<Value>0.1357157</Value>
</Prop>
<Prop Name='Index' Type='Number' Flags='0x0'>
<Value>31</Value>
</Prop>
<Prop Name='StepName' Type='String' Flags='0x0'>
<Value>MainSequence Callback</Value>
</Prop>
<Prop Name='StepGroup' Type='String' Flags='0x0'>
<Value>Main</Value>
</Prop>
<Prop Name='StepId' Type='String' Flags='0x0'>
<Value>ID#:xnW0PT0ORE2el7wF7uaxyB</Value>
</Prop>
<Prop Name='Id' Type='Number' Flags='0x0'>
<Value>4</Value>
</Prop>
<Prop Name='StepType' Type='String' Flags='0x0'>
<Value>SequenceCall</Value>
</Prop>
<Prop Name='BlockLevel' Type='Number' Flags='0x0'>
<Value>0</Value>
</Prop>
<Prop Name='SequenceFilePostResultListEntry' Type='Obj' Flags='0x0'>
<Prop Name='ResultList' Type='Array' LBound='[0]' HBound='[]' ElementType='Obj' Flags='0x0'>
<ArrayElementPrototype Type='TEResult' Flags='0x0'>
</ArrayElementPrototype>
</Prop>
<Prop Name='SequenceFile' Type='String' Flags='0x0'>
<Value>C:\Program Files\National Instruments\TestStand 2010 SP1\Components\Models\TestStandModels\SequentialModel.seq</Value>
</Prop>
<Prop Name='Sequence' Type='String' Flags='0x0'>
<Value>SequenceFilePostResultListEntry</Value>
</Prop>
<Prop Name='Status' Type='String' Flags='0x0'>
<Value>Passed</Value>
</Prop>
</Prop>
</Prop>
您可以使用XDocument解析xml,
XDocument doc = XDocument.Load("c:\\somexmlfile.xml");
XElement xProp = doc.Root.Elements().Where(p => p.Attribute("Name").Value == "StartTime").FirstOrDefault();
if (xProp != null)
{
XElement xValue = xProp.Element("Value");
if (xValue != null && !string.IsNullOrEmpty(xValue.Value))
{
double startTimeValue = double.Parse(xValue.Value);
}
}
您的案例,您可以使用以下代碼獲取價值
string xml = @"<root><Prop Name='StartTime' Type='Number' Flags='0x0'>
<Value>171.8032865</Value>
</Prop></root>";
var doc = XDocument.Parse(xml);
foreach (var obj in doc.Descendants("Prop"))
{
Console.WriteLine(obj.Element("Value").Value);
}
您的Xml不理想,理想情況下Xml和代碼應如下所示
string xml = @"<root><Prop Name='StartTime' Type='Number' Flags='0x0'>171.8032865</Prop>
<Prop Name='StartTime' Type='Number' Flags='0x0'>172.8032865</Prop>
</root>";
var doc = XDocument.Parse(xml);
foreach (var obj in doc.Descendants("Prop"))
{
Console.WriteLine(obj.Value);
}
只需使用XmlDocument
:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Xml;
namespace DemoApp
{
class Program
{
static void Main(string[] args)
{
XmlDocument doc = new XmlDocument();
doc.LoadXml(@"
<Prop Name='StartTime' Type='Number' Flags='0x0'>
<Value>171.8032865</Value>
</Prop>");
XmlElement element = doc.DocumentElement;
XmlNode valueNode = element.ChildNodes[0];
double value = double.Parse(valueNode.InnerText);
Console.ReadLine();
}
}
}
確定...。獲取整個xml之后...
XDocument xmlDoc = XDocument.Load(@"Your file path");
var startTimes = xmlDoc.Descendants()
.Where(x => x.Attributes().Any(att => att.Name == "Name" && att.Value == "StartTime"))
.Select(x => x.Value).ToList();
這給了我一個包含值的列表:
這感覺更像您在尋找什么。
您可能需要查看Visual Studio XSD工具。 看到這個問題有關如何在命令行中運行它,或者使用的詳細信息Paste Special
菜單選項。
該工具將直接從XML生成C#類,然后您可以對其進行序列化和編程訪問。
編輯
從技術上講,這不是直接的答案(可以隨意投票)。 但是,它確實提供了一種替代解決方案,可以幫助解決讀取和寫入XML屬性的更大問題。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Xml;
namespace XMLdata
{
class Program
{
static void Main(string[] args)
{
XDocument doc = XDocument.Load("c:\\somexmlfile.xml");
XmlDocument doc1 = new XmlDocument();
doc1.LoadXml (doc.ToString());
XmlElement element = doc1.DocumentElement;
XmlNode node= element.ChildNodes[0];
double value = double.Parse(node.InnerText);
}
}
}
你可以試試這個
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.