2016-11-23 29 views
-2

xml以下があります.FolumnNameを持つ場合、FileTypeId、EngName、JpnNameを配列に取得できますか。私はTest2を持っている場合、私は2、EngName2、JpnName2をXDocumentクラスを使って文字列の配列に入れたいと思っています。あなたがメインルートが必要XDocumentクラスを使用して配列のノード値を読み取る

<Row> 
    <FolderName>Test1</FolderName> 
    <FileTypeId>1</FileTypeId> 
    <EngName>EngName1</EngName> 
    <JpnName>JpnName1</JpnName> 
    </Row> 
    <Row> 
    <FolderName>Test2</FolderName> 
    <FileTypeId>2</FileTypeId> 
    <EngName>EngName2</EngName> 
    <JpnName>JpnName2</JpnName> 
    </Row> 
    <Row> 
    <FolderName>Test3</FolderName> 
    <FileTypeId>3</FileTypeId> 
    <EngName>EngName3</EngName> 
    <JpnName>JpnName3</JpnName> 
    </Row> 

答えて

0

LINQで試してみてください。

XDocument xdoc = XDocument.Load("input.xml"); 

string yourCondition = "Test2"; 
var query = from elem in xdoc.Root.Elements("Row") 
      where elem.Element("FolderName").Value == yourCondition 
      select new 
      { 
       FileTypeId = elem.Element("FileTypeId").Value, 
       EngName = elem.Element("EngName").Value, 
       JpnName = elem.Element("JpnName").Value 
      }; 

if (query.Count() > 0) 
{ 
    var result = query.First(); 

    // You can access the fields through this: 
    string engName = result.EngName; 
    string fileTypeId = result.FileTypeId; 
    string jpnName = result.JpnName; 
} 

そして "SNN BRN" などが指摘、あなたはXMLのルート要素が必要です。

0

var doc = XDocument.Load("data.xml"); 


<Rows> 
    <Row> 
    <FolderName>Test1</FolderName> 
    <FileTypeId>1</FileTypeId> 
    <EngName>EngName1</EngName> 
    <JpnName>JpnName1</JpnName> 
    </Row> 
    <Row> 
    <FolderName>Test2</FolderName> 
    <FileTypeId>2</FileTypeId> 
    <EngName>EngName2</EngName> 
    <JpnName>JpnName2</JpnName> 
    </Row> 
    <Row> 
    <FolderName>Test3</FolderName> 
    <FileTypeId>3</FileTypeId> 
    <EngName>EngName3</EngName> 
    <JpnName>JpnName3</JpnName> 
    </Row> 
</Rows> 
関連する問題