我遇到了一个月前从现有XML文件中获取值到我的c#程序的问题 我已经在stackoverflow中尝试了许多不同的答案,但这并不是我所需要的 我想分享我在这里找到的解决方案,这样可以帮助其他人遇到类似的问题。
答案 0 :(得分:1)
我已经解决了这个问题但希望与您分享此解决方案。
注意:这仅适用于内容相同的xml文件。
让我告诉你我是如何修理的:
第一步: 我创建了一个xml结构的类,与我的xml文件完全相同
[XmlRoot("Data")]
public class Data
{
[XmlElement("Msg")]
public Msg Msgs { get; set; }
}
public class Msg
{
[XmlElement]
public string Type { get; set; }
[XmlElement]
public string UserID { get; set; }
[XmlElement]
public string SerialNumber { get; set; }
[XmlElement]
public string DateTime { get; set; }
[XmlElement("Rows")]
public Rows RowsObj { get; set; }
}
public class Rows
{
[XmlElement("Row")]
public List<Row> RowsList { get; set; }
}
public class Row
{
[XmlElement]
public string InvoiceCode { get; set; }
[XmlElement]
public string ServiceCode { get; set; }
[XmlElement]
public string BranchID { get; set; }
[XmlElement]
public string AbonCode { get; set; }
[XmlElement]
public string Amount { get; set; }
[XmlElement]
public string PaymentDate { get; set; }
[XmlElement]
public string ReceiptNumber { get; set; }
[XmlElement]
public string PaymentSite { get; set; }
[XmlElement]
public string PaymentInstrument { get; set; }
[XmlElement]
public string BankHeadOfficeCode { get; set; }
}
这是我的.xml文件结构
<?xml version="1.0" encoding="utf-8"?>
<Data>
<Header/>
<Msg>
<Type>INVOICE_PAY_APUS</Type>
<UserID>888888</UserID>
<SerialNumber>8210089</SerialNumber>
<DateTime>2015-04-15T15:20:17</DateTime>
<Rows>
<Row>
<InvoiceCode>1414016335DR</InvoiceCode>
<BranchID>981008</BranchID>
<AbonCode>1414016335</AbonCode>
<Amount>80.00</Amount>
<PaymentDate>2015-04-15T15:20:03</PaymentDate>
<ReceiptNumber>95037101</ReceiptNumber>
<PaymentSite>GPP</PaymentSite>
<PaymentInstrument>4</PaymentInstrument>
<BankHeadOfficeCode>qwerty</BankHeadOfficeCode>
</Row>
<Row>
<InvoiceCode>1414016335XH</InvoiceCode>
<BranchID>981005</BranchID>
<AbonCode>1414016335</AbonCode>
<Amount>34.00</Amount>
<PaymentDate>2015-04-15T15:20:03</PaymentDate>
<ReceiptNumber>95037103</ReceiptNumber>
<PaymentInstrument>4</PaymentInstrument>
<PaymentSite>GPP</PaymentSite>
<BankHeadOfficeCode>AZRTAZ22</BankHeadOfficeCode>
</Row>
</Rows>
</Msg>
</Data>
如您所见,我在数据等下面有一个名为数据和消息元素的根元素。
第二步:
在我的主类控制台应用程序中,我试图访问放置xml文件的文件夹,之后我从xml读取数据并将其解析为我的对象。
class Program
{
static void Main(string[] args)
{
string mainPath = "C:\\xmlTest"; //folder with my xml files goes here, it's optional, you can change it to whatever you want
Data data = new Data();
foreach (string file in Directory.EnumerateFiles(mainPath, "*.xml"))
{
XmlSerializer mySerializer = new XmlSerializer(typeof(Data));
StreamReader streamReader = new StreamReader(file);
data = (Data)mySerializer.Deserialize(streamReader);
streamReader.Close();
List<Row> rows = data.Msgs.RowsObj.RowsList;
foreach (var row in rows)
{
//do stuff here
//example: string paymentType = row.InvoiceCode.Substring(row.InvoiceCode.Length - 2);
}
}
}
}
那就是它,希望它会帮助你们。