如何在不使用数据库的情况下存储数据以及如何检索它们?

时间:2010-04-09 11:26:40

标签: c# .net winforms

我正在解析html文件以通过列名提取表格信息。我希望让用户为列名提供输入。并根据该列名称将提取表格信息。

现在,用户将输入的列名称,根据列名称,我想从html文件中找到表格信息。

但是我应该在哪里存储用户输入的列名?以及如何检索它们?我不想使用数据库。

编辑:我们如何在xml文件中存储数据?如何从中检索数据?如何更新xml文件以存储数据?就像我有3个列名Name, Address,Phone no一样,该用户将输入可能的列名,如Nm,Add,PhNo.Nam,Addre,PhoNo等等。

8 个答案:

答案 0 :(得分:10)

很多人一直在谈论XML,这是一个好主意。但是,如果Linq可供您使用,那么您应该非常考虑使用Linq to XML而不是SAX / DOM解析。

与SAX和DOM解析器相比,Linq to XML使得解析,创建和编辑XML文件变得更加容易。使用SAX / DOM解析通常需要大量循环来获取正确的元素或通过节点导航。

从MSDN获取的示例:
使用DOM解析:

XmlDocument doc = new XmlDocument();
XmlElement name = doc.CreateElement("Name");
name.InnerText = "Patrick Hines";
XmlElement phone1 = doc.CreateElement("Phone");
phone1.SetAttribute("Type", "Home");
phone1.InnerText = "206-555-0144";        
XmlElement phone2 = doc.CreateElement("Phone");
phone2.SetAttribute("Type", "Work");
phone2.InnerText = "425-555-0145";        
XmlElement street1 = doc.CreateElement("Street1");        
street1.InnerText = "123 Main St";
XmlElement city = doc.CreateElement("City");
city.InnerText = "Mercer Island";
XmlElement state = doc.CreateElement("State");
state.InnerText = "WA";
XmlElement postal = doc.CreateElement("Postal");
postal.InnerText = "68042";
XmlElement address = doc.CreateElement("Address");
address.AppendChild(street1);
address.AppendChild(city);
address.AppendChild(state);
address.AppendChild(postal);
XmlElement contact = doc.CreateElement("Contact");
contact.AppendChild(name);
contact.AppendChild(phone1);
contact.AppendChild(phone2);
contact.AppendChild(address);
XmlElement contacts = doc.CreateElement("Contacts");
contacts.AppendChild(contact);
doc.AppendChild(contacts);

使用Linq to XML:

XElement contacts =
    new XElement("Contacts",
        new XElement("Contact",
            new XElement("Name", "Patrick Hines"),
            new XElement("Phone", "206-555-0144", 
                new XAttribute("Type", "Home")),
            new XElement("phone", "425-555-0145",
                new XAttribute("Type", "Work")),
            new XElement("Address",
                new XElement("Street1", "123 Main St"),
                new XElement("City", "Mercer Island"),
                new XElement("State", "WA"),
                new XElement("Postal", "68042")
            )
        )
    );

更容易做,更清晰。

修改
将XML树保存到contacts.xml:

// using the code above
contact.Save("contacts.xml");

加载contacts.xml文件:

//using the code above
XDocument contactDoc = XDocument.Load("contacts.xml"); 

要更新树的元素,doc中有一些可以执行此操作的函数,具体取决于您要执行的操作

答案 1 :(得分:3)

也许您可以序列化DataTable,但请记住,如果用数据填充它,这可能会变得很大并且需要花费大量时间来序列化或反序列化。如果以其他方式存储数据,您可能希望将列信息存储在配置/项目文件中。

HTH, -sa

答案 2 :(得分:1)

使用数据库。如果您不想设置客户端/服务器架构的麻烦,请使用SQLite,其中包含多个.Net版本或SQL Server Express

答案 3 :(得分:1)

数据库的替代方案是:http://www.filehelpers.com/

答案 4 :(得分:1)

您可以使用XML文件作为替代方案,但使用SQLite似乎更为可取。 XML工具位于System.Xml命名空间下。您可以使用XMLReader / Writer类来管理文件中的信息。 MSDN page上有一些很好的用法示例。

答案 5 :(得分:1)

如果只有十列,如何在App.Config中存储分隔字符串?

答案 6 :(得分:0)

如果您必须选择,而不是数据库;然后我会使用Xml,当文件变大时使用SAX进行解析。

了解如何Manipulate XML File Data Using C#

<强> - 编辑 -

这是对你的评论的回应。让我们假设您有一个包含以下控件的屏幕:

  1. TextBox as txtColumnName;当用户提供列名并单击“添加”按钮时,将其另存为xml属性。
  2. ComboBox作为cbxColumns;选择当前列
  3. TextBox为txtValue;如果提供了此项,则将值保存在“列组合”中选择的列中。
  4. 添加按钮;你也可以添加删除,更新按钮。
  5. 请浏览示例链接,它将帮助您在运行时添加/删除/更新节点。您可以使用包含所有CRUD操作的XmlDatabaseWrapper类。

答案 7 :(得分:0)

我认为使用XML文件将是您的最佳选择。

看看这篇文章,它清楚地展示了如何操作XML文件。

http://www.developer.com/article.php/3489611

HTH