使用Linq编辑元素并将其保存到XML文件

时间:2016-11-23 17:33:54

标签: c# xml wpf linq listbox

我正在尝试制作一个小型XML编辑器。它加载XML文件,在列表框中显示所有书名(在我的示例文件中)。单击标题会在文本框中显示有关该书的所有信息。如果应修改信息,则用户可以单击“编辑”按钮,现在可以在新文本框中编辑信息。最后,保存更改并清除两个文本框 - 如果可能,应将新更新的XML文件中的标题重新加载到列表框中(screenshot)。

由于this post,列表框和第一个文本框操作正常。 当我尝试将XML值发送到第二个文本框时出现问题。任何更改都不会保存,如果是,则XML文件的其余部分将消失。

我认为解决方案可能包括将信息(及其更改)添加到新的XML元素然后删除旧的元素,但到目前为止,我已经尝试了一段时间了,我只是可以'弄清楚该怎么做。出于同样的原因,我知道它的风格很糟糕,我的代码在问题开始时停止了。如果有人可以帮助我,我会很高兴。

我的示例XML:

<?xml version='1.0'?>
<!-- This file represents a fragment of a book store inventory database -->
<books>
  <book genre="autobiography">
    <title>The Autobiography of Benjamin Franklin</title>
    <author>Franklin, Benjamin</author>
    <year>1981</year>
    <price>8.99</price>
  </book>
  <book genre="novel">
    <title>The Confidence Man</title>
    <author>Melville, Herman</author>
    <year>1967</year>
    <price>11.99</price>
  </book>
  <book genre="philosophy">
    <title>The Gorgias</title>
    <author>Plato</author>
    <year>1991</year>
    <price>9.99</price>
  </book>
</books>

我的.cs

    private void btnLoadXML_Click(object sender, EventArgs e)
    {
        var xmlDoc = XDocument.Load("books03.xml");

        var elements = from ele in xmlDoc.Elements("books").Elements("book")
                       where ele != null
                       select ele;

        bookList = elements.ToList();

        foreach (var book in bookList)
        {
            string title = book.Element("title").Value;
            listBox1.Items.Add(title);
        }
    }

    private void listBox1_SelectedIndexChanged(object sender, EventArgs e)
    {
        var book = bookList[listBox1.SelectedIndex];

        textBox1.Text = 
            "Title: " + book.Element("title").Value + Environment.NewLine +
            "Author: " + book.Element("author").Value + Environment.NewLine +
            "Year: " + book.Element("year").Value + Environment.NewLine +
            "Price: " + book.Element("price").Value;
    }

    private void btnEdit_Click(object sender, EventArgs e)
    {
        textBox2.Visible = true;
        btnSaveClose.Visible = true;
    }
}

1 个答案:

答案 0 :(得分:0)

试试xml linq:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Xml;
using System.Xml.Linq;

namespace ConsoleApplication1
{
    class Program
    {
        const string FILENAME = @"c:\temp\test.xml";
        static void Main(string[] args)
        {
            XDocument doc = XDocument.Load(FILENAME);
            string searchName = "The Autobiography of Benjamin Franklin";
            XElement book = doc.Descendants("book").Where(x => (string)x.Element("title") == searchName).FirstOrDefault();

            XElement price = book.Element("price");

            price.SetValue("10.00");
        }
    }
}