0

是否可以使用 asp.c# 获取和编辑 xml 的特定值?例如,我的 xml 文件:

<posters>
  <poster>
    <quantity>100</quantity>
    <stock>100</stock>
    <price>88</price>
  </poster>
  <poster>
    <quantity>100</quantity>
    <stock>150</stock>
    <price>95</price>
  </poster>
  <poster>
    <quantity>200</quantity>
    <stock>100</stock>
    <price>95</price>
  </poster>
  <poster>
    <quantity>200</quantity>
    <stock>150</stock>
    <price>100</price>
  </poster>
</posters>

数量 == 200 & 库存 == 100 和数量 == 100 & 库存 == 150 有两个 95。我可以从数量 == 200 和库存 == 100 中获取值 95 并编辑它而不修改相同的 95数量 == 100 &库存 == 150?

我尝试使用“SelectSingleNode”和“SelectNode”,但它们帮不了我。我想得到类似 sql 的结果——“从数量 = 200 且库存 = 100 的海报中选择价格”。

有什么建议么?

XML 到数据集:

string xmlDocString = Server.MapPath("MyXMLFile.xml");
    DataSet dataSet = new DataSet();
    dataSet.ReadXml(xmlDocString);
    GridView1.DataSource = dataSet.Tables[0].DefaultView;
    GridView1.DataBind();
4

2 回答 2

1

使用 XPath 表达式和这个 XML 库

int quantity = 200;
int stock = 100;
int newPrice = 55;
XElement root = XElement.Load(file);
XElement poster = root.XPathElement("//poster[quantity={0} and stock={1}]", 
                                    quantity, stock);
poster.Set("price", newPrice, false); // false for set child ELEMENT value
于 2013-06-24T18:40:17.037 回答
0

您可以使用LINQ to XML。它将允许您拥有“像 sql”一样的代码

这是在 LINQPad 中工作的代码示例

void Main()
{
    var xml = @"<posters>
  <poster>
    <quantity>100</quantity>
    <stock>100</stock>
    <price>88</price>
  </poster>
  <poster>
    <quantity>100</quantity>
    <stock>150</stock>
    <price>95</price>
  </poster>
  <poster>
    <quantity>200</quantity>
    <stock>100</stock>
    <price>95</price>
  </poster>
  <poster>
    <quantity>200</quantity>
    <stock>150</stock>
    <price>100</price>
  </poster>
</posters>";

    var doc = XDocument.Parse(xml);

var value = (from x in doc.Descendants("poster")
        where x.Element("stock").Value == "100" 
        && x.Element("quantity").Value == "200"
        select x.Element("price")).FirstOrDefault();

    if (value != null)
        value.SetValue("1000");

    value.Dump();
    doc.Dump();
}
于 2013-06-24T19:15:15.783 回答