以下代码段返回xml文档
public XmlDocument GetXMLFile(int ID)
{
List<UserInfoBE> data = GetById(ID);
DataSet ds = ConvertGenericsListToDataSet(data);
XmlDocument XmlDoc = new XmlDocument();
XmlDocument doc = GenerateXMLDeclaration(XmlDoc);//Create xml Declaration
doc = AddTableTag(doc);//Create parent node USERDATA
foreach (DataRow dr in ds.Tables[0].Rows)
{
doc = AddUserinfoTag(doc, dr[8].ToString(), Convert.ToInt32(dr[31].ToString()), Convert.ToString(dr[32].ToString()), dr[3].ToString());
}
doc = SetHeirarchyLevel(doc);
string _errorFile = AppDomain.CurrentDomain.BaseDirectory + "XML\\";
System.IO.Directory.CreateDirectory(_errorFile);
_errorFile += "FIle" + DateTime.Now.ToString("dd-MM-yyyy") + ".xml";
XmlNodeList nodes = doc.SelectNodes("USERDATA/Userinfo");
XmlDocument newXMLDoc = new XmlDocument();
XmlDocument newDoc = GenerateXMLDeclaration(newXMLDoc);
newDoc.AppendChild(nodes);
doc.Save(_errorFile);
return doc;
}
XML文件格式:
<?xml version="1.0"?>
<USERDATA>
<Userinfo>
<Userinfo>
<Userinfo>
<Userinfo>
<Userinfo>
<Userinfo/>
<Userinfo>
<Userinfo/>
</Userinfo>
</Userinfo>
<Userinfo>
<Userinfo/>
<Userinfo/>
</Userinfo>
</Userinfo>
</Userinfo>
</Userinfo>
</Userinfo>
</EDVDATA>
问题如何以下列格式获取文件
<Userinfo>
<Userinfo>
<Userinfo>
<Userinfo>
<Userinfo>
<Userinfo/>
<Userinfo>
<Userinfo/>
</Userinfo>
</Userinfo>
<Userinfo>
<Userinfo/>
<Userinfo/>
</Userinfo>
</Userinfo>
</Userinfo>
</Userinfo>
</Userinfo>
我所尝试的是将返回doc对象(Xml文件)保存在文件夹中。 然后创建一个新的xmldocument对象并尝试在新的xmlobject
中附加哪个userinfo结构(就在上面)的XmlnodelistnewDoc.AppendChild(节点); line抛出错误
无法从'System.Xml.XmlNodeList'转换为'System.Xml.XmlNode'
非常感谢任何帮助。
答案 0 :(得分:1)
您正尝试追加多个节点,但该函数一次只能追加单个节点。试试这个:
foreach(XmlNode node in nodes)
{
newDoc.AppendChild(node);
}
答案 1 :(得分:0)
像这样解决了,
public XmlDocument GetXMLFile(int ID) {
List<UserInfoBE> data = GetById(ID);
DataSet ds = ConvertGenericsListToDataSet(data);
XmlDocument XmlDoc = new XmlDocument();
XmlDocument doc = GenerateXMLDeclaration(XmlDoc);//Create xml Declaration
doc = AddTableTag(doc);//Create parent node USERDATA
foreach (DataRow dr in ds.Tables[0].Rows)
{
doc = AddUserinfoTag(doc, dr[8].ToString(), Convert.ToInt32(dr[31].ToString()), Convert.ToString(dr[32].ToString()), dr[3].ToString());
}
doc = SetHeirarchyLevel(doc);
XmlNodeList nodes = doc.SelectNodes("USERDATA/Userinfo");
XmlDocument newXMLDoc = new XmlDocument();
XmlDocument newDoc = GenerateXMLDeclaration(newXMLDoc);
foreach (XmlNode node in nodes)
{
newDoc.AppendChild(newDoc.ImportNode(node,true));
}
return newDoc;
}