2013-03-15 275 views
1

我有下面的XML元素获取过滤:通过属性

<?xml version="1.0" encoding="utf-8"?> 
<assertions> 
    <assertion id="SLM_CekNonNegative"> 
     <satisfied count="36"/> 
     <unsatisfied count="4"> 
      <message xml:lang="id">(Record ID = ID_2) SLM: Jumlah bulan lalu, jumlah bulan laporan, jumlah hari tunggakan, dan jumlah tunggakan pokok tidak boleh kosong dan harus diisi >= 0</message> 
      <message xml:lang="id">(Record ID = ID_2) SLM: Jumlah bulan lalu, jumlah bulan laporan, jumlah hari tunggakan, dan jumlah tunggakan pokok tidak boleh kosong dan harus diisi >= 0</message> 
      <message xml:lang="id">(Record ID = ID_2) SLM: Jumlah bulan lalu, jumlah bulan laporan, jumlah hari tunggakan, dan jumlah tunggakan pokok tidak boleh kosong dan harus diisi >= 0</message> 
      <message xml:lang="id">(Record ID = ID_2) SLM: Jumlah bulan lalu, jumlah bulan laporan, jumlah hari tunggakan, dan jumlah tunggakan pokok tidak boleh kosong dan harus diisi >= 0</message> 
     </unsatisfied> 
    </assertion> 
    <assertion id="Base_CekJangkaWaktuMulaiLebihMudaJatuhTempo"> 
     <satisfied count="10"/> 
     <unsatisfied count="0"/> 
    </assertion> 
    <assertion id="SLM_CekJumlahBulanKrgDrNilaiKontrak"> 
     <satisfied count="10"/> 
     <unsatisfied count="0"/> 
    </assertion> 
    <assertion id="Base_CekTanggalLebihMudaTanggalPelaporan"> 
     <satisfied count="10"/> 
     <unsatisfied count="0"/> 
    </assertion> 
    <assertion id="SLM_CekNilaiKontrak"> 
     <satisfied count="2"/> 
     <unsatisfied count="8"> 
      <message xml:lang="id">(Record ID = ID_10) Nilai kontrak harus > 0</message> 
      <message xml:lang="id">(Record ID = ID_9) Nilai kontrak harus > 0</message> 
      <message xml:lang="id">(Record ID = ID_8) Nilai kontrak harus > 0</message> 
      <message xml:lang="id">(Record ID = ID_7) Nilai kontrak harus > 0</message> 
      <message xml:lang="id">(Record ID = ID_6) Nilai kontrak harus > 0</message> 
      <message xml:lang="id">(Record ID = ID_5) Nilai kontrak harus > 0</message> 
      <message xml:lang="id">(Record ID = ID_2) Nilai kontrak harus > 0</message> 
      <message xml:lang="id">(Record ID = ID_1) Nilai kontrak harus > 0</message> 
     </unsatisfied> 
    </assertion> 
    <assertion id="SLM_CekGolNasabah"> 
     <satisfied count="9"/> 
     <unsatisfied count="1"> 
      <message xml:lang="id">(Record ID = ID_2) Golongan nasabah tidak boleh diisi sandi bank pelapor sendiri</message> 
     </unsatisfied> 
    </assertion> 
    <assertion id="BS-IF_CekSLMVls"> 
     <satisfied count="1"/> 
     <unsatisfied count="0"/> 
    </assertion> 
    <assertion id="BS-IF_CekSLMIDR"> 
     <satisfied count="1"/> 
     <unsatisfied count="0"/> 
    </assertion> 
    <assertion id="Base_CekHubunganTidakTerkaitStatusLainnya"> 
     <satisfied count="8"/> 
     <unsatisfied count="2"> 
      <message xml:lang="id">(Record ID = ID_3) Base: "Status hubungan dengan Bank" harus terisi sandi 9 jika Kolom "Klasifikasi Nasabah - Hubungan dengan bank" terisi sandi 2</message> 
      <message xml:lang="id">(Record ID = ID_2) Base: "Status hubungan dengan Bank" harus terisi sandi 9 jika Kolom "Klasifikasi Nasabah - Hubungan dengan bank" terisi sandi 2</message> 
     </unsatisfied> 
    </assertion> 
    <assertion id="Base_CekLembagaNilaiPemeringkat"> 
     <satisfied count="0"/> 
     <unsatisfied count="0"/> 
    </assertion> 
    <assertion id="Base_CekNeracaMinNol"> 
     <satisfied count="0"/> 
     <unsatisfied count="0"/> 
    </assertion> 
    <assertion id="Base_CekNilaiAgunanMinNol"> 
     <satisfied count="0"/> 
     <unsatisfied count="0"/> 
    </assertion> 
    <assertion id="Base_CekPersentaseMaksimal100"> 
     <satisfied count="0"/> 
     <unsatisfied count="0"/> 
    </assertion> 
    <assertion id="Base_CekLembaga-Tanggal-NilaiPeringkat"> 
     <satisfied count="0"/> 
     <unsatisfied count="0"/> 
    </assertion> 
    <assertion id="Base_CekIdentifier"> 
     <satisfied count="1"/> 
     <unsatisfied count="0"/> 
    </assertion> 
    <assertion id="Base_CekNomor-JumlahAgunan"> 
     <satisfied count="0"/> 
     <unsatisfied count="0"/> 
    </assertion> 
    <assertion id="Base_CekEligibilityJenisAgunan"> 
     <satisfied count="0"/> 
     <unsatisfied count="0"/> 
    </assertion> 
    <assertion id="Base_CekSifat-GolonganPenerbitAgunan"> 
     <satisfied count="0"/> 
     <unsatisfied count="0"/> 
    </assertion> 
    <assertion id="Base_cekPeriod"> 
     <satisfied count="1"/> 
     <unsatisfied count="0"/> 
    </assertion> 
</assertions> 

我怎样才能得到的<assertion id="SLM_CekNonNegative">这是SLM_CekNonNegative价值?

下面是我到目前为止的代码:

string pathasr = @"D:\HARPITNAS\dari mbak julia\logs\123456789-2012-09-30-BSMS10.xml-assertions2.xml"; 
List<string> msg = new List<string>(); 
XmlDocument doc = new XmlDocument(); 
doc.Load(pathasr); 

foreach (XmlNode node in doc.DocumentElement) 
{ 
    string thevaluethatiwantvariable = string.Empty; 
    thevaluethatiwantvariable = ? ; 

    if (node.LastChild.HasChildNodes == true) 
    { 
      string count = node.LastChild.ChildNodes.Count.ToString(); 
      foreach (XmlNode y in node.LastChild.ChildNodes) 
      { 
       string masg = y.InnerXml; 
       msg.Add(masg); 
      } 
    } 
} 

此代码不会得到我想要的价值。当我调试它时,我可以看到它没有得到正确的值。有可能获得我想要的价值吗?

回答

4
thevaluethatiwantvariable = doc.DocumentElement.SelectSingleNode("//assertion[@name = 'id']/@value").Value; 

欲了解更多信息: http://www.w3schools.com/xpath/xpath_syntax.asp

+0

我已经按照你的解决方案,但我得到的错误'对象引用为空' – Sabilv 2013-03-15 14:32:50

+0

如果你没有对应的_SINGLE_节点,就会发生坏事。修正示例数据以反映您的真实情况。 – BlackICE 2013-03-15 16:32:33

+0

我已经修复了示例XML,为您的预先 – Sabilv 2013-03-18 03:39:01

2

而不使用XPath这将是这样的:

string theValue = doc.DocumentElement["assertion"].Attributes["id"].Value; 

而且也没有必要对任何类型的循环。

+0

我需要foreach循环,因为元素不仅仅是一个其中一些,如果我使用你的代码,它只给出第一个元素值...? – Sabilv 2013-03-15 14:28:40

+1

@SabilValdano那么你的例子是不完整的。 XPath解决方案也将只给你一个字符串。给我们完整的例子。 – Dialecticus 2013-03-15 16:28:26

+0

我已经修复了XML示例thx ... – Sabilv 2013-03-18 03:39:30