0

我有这种格式的 xml 文件。

<Questions>
    <Question>
      <questiontext>The remains of the Tabon man was discovered in the Tabon Caves in     </questiontext>
      <choice1>Lipuun Point</choice1>
      <choice2>Callao Cave</choice2>
      <choice3>Hinagdanan Cave</choice3>
      <choice4>Montfort Bat Sanctuary</choice4>
      <answer>Lipuun Point</answer>
    </Question>
</Questions>

我正在通过记事本++ 创建它。并像这样阅读它。

System.IO.Stream stream = TitleContainer.OpenStream("Content//Level1Trivia.xml");
XDocument doc = XDocument.Load(stream);            
level1Trivia = new List<Trivias>();
level1Trivia = (from question in doc.Descendants("Question")
    select new Trivias()
    {
        Question = question.Element("questiontext").Value,
        Choice1 = question.Element("choice1").Value,
        Choice2 = question.Element("choice2").Value,
        Choice3 = question.Element("choice3").Value,
        Choice4 = question.Element("choice4").Value,
        Answer = question.Element("answer").Value,
    }).ToList();

问题是。我可以读取外部创建的 xml 文件。但我不知道如何通过代码创建/写入 xml 文件。并使用我给定的代码来阅读它。有任何想法吗?谢谢!

4

2 回答 2

1

使用 XElement 对象。例子:

XDocument document = new XDocument();
XElement rootElement = new XElement("Questions");

foreach(Question question in QuestionsCollection)
{
    XElement questionElement = new XElement("Question");

    questionElement.Add(new XElement("questiontext") { Value = question.Text });
    questionElement.Add(new XElement("choice1") { Value = question.Question1 });
    questionElement.Add(new XElement("choice2") { Value = question.Question2 });
    questionElement.Add(new XElement("choice3") { Value = question.Question3 });
    questionElement.Add(new XElement("choice4") { Value = question.Question4 });
    questionElement.Add(new XElement("answer") { Value = question.Answer });

    rootElement.Add(questionElement);
}

document.Add(rootElement);
document.Save("C:\Location.xml");

像这样的东西应该工作。

于 2013-10-13T13:42:09.647 回答
0

通过将 XML 保存文件路径传递给CreateXml方法,使用此代码创建和保存 XML 文件

查看此链接 Create and Save XML file in C#/VB

public void CreateXml(string XmlPath)
{ 
try
            {
                if (ds.Tables[0].Rows.Count > 0)
                {
                    string Name = string.Empty;
                    int Age = 0;
                    int Experience = 0;

                    Name = ds.Tables[0].Rows[0]["EmployeeName"].ToString();
                    Age = int.Parse(ds.Tables[0].Rows[0]["EmployeeAge"].ToString());
                    Experience = int.Parse(ds.Tables[0].Rows[0]["EmployeeExperience"].ToString());

                    string xml = XmlTemplate().ToString().Replace("EmpName", Name).Replace("EmpAge", Age.ToString(),Replace("EmpExperience", Experience.ToString());
                    XmlPath = XmlPath + "Employee_" + Name + ".xml";
                    XmlDocument xdoc = new XmlDocument();
                    xdoc.LoadXml(xml);
                    xdoc.Save(XmlPath);
                    lblMessage.Text = "XML Created Successfully.";
                }
                else
                {
                    lblMessage.Text = "InValid Employee ID.";
                }
            }
            catch (Exception ex)
            {
                lblMessage.Text = ex.Message.ToString();
            }
}


public string XmlTemplate()
{

            string Xml = "<Employee>" +
                            "<Name>EmpName</Name>" +
                            "<Age>EmpAge</Age>" +
              "<Experience>EmpExperience</Experience>" +
                            "</Employee>";
            return Xml;
}

希望这对您有所帮助。谢谢。

于 2015-04-24T12:08:04.147 回答