我正在解析xml文件。
xml的第一行看起来像;
<DataSetMenu xmlns="http://tempuri.org/DataSetMenu.xsd">
我正在使用下面的代码来解析xml。
string filename = Request.QueryString["file"].ToString();
XElement xdocument = XElement.Load(Server.MapPath("xml\\" + filename));
xdocument.Attribute("xmlns").Remove();
IEnumerable<XElement> MenuGroups = xdocument.Elements();
sb.Append("<link href='StyleSheet.css' rel='stylesheet' type='text/css' />");
foreach (var xel in MenuGroups)
{
if (xel.Elements("MenuCatName").Any())
{
Int32 MenuCatID = Convert.ToInt32(xel.Element("MenuCatID").Value);
string MenuCatName = xel.Element("MenuCatName").Value;
sb.Append("<div class='CategoryDiv'><h1 class='category'>" + MenuCatName + " </h1>");
GetGroupItems(xdocument, MenuCatID);
}
}
但是当xml文件的第一个节点包含:
时 xmlns="http://tempuri.org/DataSetMenu.xsd"
根本不起作用。当我尝试访问xml的数据时,它会给我错误,对象引用未设置为对象的实例
XML文件
<DataSetMenu xmlns="http://tempuri.org/DataSetMenu.xsd">
<MenuCategories>
<MenuCatID>10108</MenuCatID>
<MenuCatName>SPEICALS</MenuCatName>
<BusinessEntityID>20137</BusinessEntityID>
<DisplayIndex>10107</DisplayIndex>
<MenuCatDesc />
<Visible>true</Visible>
<ImagePath />
</MenuCategories>
<MenuCategories>
<MenuCatID>10109</MenuCatID>
<MenuCatName>GENERAL MENU</MenuCatName>
<BusinessEntityID>20137</BusinessEntityID>
<DisplayIndex>10108</DisplayIndex>
< MenuCatDesc />
<Visible>true</Visible>
<ImagePath />
</MenuCategories>
<MenuGroups>
<MenuGroupID>110079</MenuGroupID>
<MenuCatID>10108</MenuCatID>
<MenuGroupName>SPECIAL OFFERS</MenuGroupName>
<MenuGroupDesc />
<Visible>true</Visible>
<DisplayIndex>0</DisplayIndex>
<MenuTypeID>1</MenuTypeID>
<ImagePath />
<ServiceTimeEnforced>false</ServiceTimeEnforced>
<ServiceStartTime>1900-01-01T11:00:00-06:00</ServiceStartTime>
<ServiceEndTime>1900-01-01T15:00:00-06:00</ServiceEndTime>
<Monday>true</Monday>
<Tuesday>true</Tuesday>
<Wednesday>true</Wednesday>
<Thursday>true</Thursday>
<Friday>true</Friday>
<Saturday>true</Saturday>
<Sunday>true</Sunday>
</MenuGroups>
</DataSetMenu>
给我一个解决方案,以便它正常工作。或以任何方式删除此属性。
感谢。
现在它正在这里工作
private void GetGroupItems(XElement xdocument, Int32 MenuCatID)
{
var MenuGroup = from nm in xdocument.Elements("MenuGroups")
where (int)nm.Element("MenuCatID") == MenuCatID
select nm;
foreach (XElement GroupName in MenuGroup)
{
Int32 MenuGroupID = Convert.ToInt32(GroupName.Element("MenuGroupID").Value);
string MenuGroupName = GroupName.Element("MenuGroupName").Value;
sb.Append("<div class='IType'>" + MenuGroupName + " </div>");
sb.Append("<table class='restaurantlist'><tbody><tr><td class='righttd'>");
GetMenuItems(MenuGroupID, xdocument);
sb.Append("</td></tr></tbody></table>");
sb.Append("<div class='restaurantlistdiv'><div style='clear: both;'></div>");
}
}
请告诉我,我该如何修改?
答案 0 :(得分:2)
在查询XML时必须指定命名空间。
创建XNamespace
实例:
var ns = XNamespace.Get("http://tempuri.org/DataSetMenu.xsd");
然后使用XNamespace
+ String operator implementation:
public static XName operator +(
XNamespace ns,
string localName
)
在Elements()
方法调用中,如下:
IEnumerable<XElement> MenuGroups = xdocument.Elements();
sb.Append("<link href='StyleSheet.css' rel='stylesheet' type='text/css' />");
foreach (var xel in MenuGroups)
{
if (xel.Elements(ns + "MenuCatName").Any())
{
Int32 MenuCatID = Convert.ToInt32(xel.Element(ns + "MenuCatID").Value);
string MenuCatName = xel.Element(ns + "MenuCatName").Value;
sb.Append("<div class='CategoryDiv'><h1 class='category'>" + MenuCatName + " </h1>");
GetGroupItems(xdocument, MenuCatID);
}
}
答案 1 :(得分:0)
这里要记住的关键是你没有使用属性,而是使用名称空间声明。这就是为什么你不能删除属性的原因。查看C#: How to remove namespace information from XML elements处的建议是否有帮助。