使用Linq to XML从XML文档中删除xmlns="something"。

3

我正在解析一个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>");
    }
}

请告诉我,我应该如何修改这个?


这是一个非常大的文件。我先展示给你前几个节点。 - Code Rider
我已经更新了我的问题,并附上了XML代码。 - Code Rider
我认为更有意义的做法是去找XML文件的原始创建者,并告诉他们给你一个带有有效命名空间的XML文件……如果可能的话。 - Steve Wellens
2个回答

2

当您查询XML时,必须指定命名空间。

创建XNamespace实例:

var ns = XNamespace.Get("http://tempuri.org/DataSetMenu.xsd");

然后使用XNamespace + String 运算符实现

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);
    }
}

哦,非常感谢。它正在工作。但是我在某个地方遇到了问题。这也是由于命名空间的原因。请告诉我如何解决它。我正在更新我的问题。谢谢。 - Code Rider
我已更新我的问题。请检查最后添加的代码。我需要你再帮我一点,解决它。谢谢。 - Code Rider
现在我已经在“XNamespace.Get()”中给出了静态命名空间。但如果我想让它变成动态的呢?因为不同的XML文件可能包含不同的命名空间。我能做到这一点吗? - Code Rider

0

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接