Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 4057368
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 20, 20262026-05-20T14:56:39+00:00 2026-05-20T14:56:39+00:00

I have an XML having multiple <Page Pageid=1> nodes. All such nodes have <Para

  • 0

I have an XML having multiple <Page Pageid="1"> nodes. All such nodes have <Para Paraid="1"> nodes under them. I want to do make single occurence of <Page> node such that all <Para> nodes belonging to same <Page> node are shown as child of particular page. e.g.

INPUT:

<Page PageID="**1**">
   <Para ParaID="1">
     <some nodes as child of para>
   </Para>
</Page>
<Page PageID="**2**">
   <Para ParaID="**1**">
     <some nodes as child of para>
   </Para>
</Page>
<Page PageID="**1**"> <!Page 1 encountered again>
   <Para ParaID="**1**">
     <some nodes as child of para>
   </Para>
</Page>
<Page PageID="**3**">
   <Para ParaID="**1**">
     <some nodes as child of para>
   </Para>
</Page>

Expected OUTPUT:

<Page PageID="**1**">
   <Para ParaID="**1**">
     <some nodes as child of para>
   </Para>
   <Para ParaID="**2**">           <!all <Para> of Page 1 are under single <Page> node>
     <some nodes as child of para>
   </Para>
</Page>
<Page PageID="**2**">
   <Para ParaID="**1**">
     <some nodes as child of para>
   </Para>
</Page>
<Page PageID="**3**">
   <Para ParaID="**1**">
     <some nodes as child of para>
   </Para>
</Page>
  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-20T14:56:40+00:00Added an answer on May 20, 2026 at 2:56 pm

    If you are using .NET 3.5, you can use the XDocument family and Linq extensions to make fairly light work of the task:

    var doc1 = XDocument.Parse(stringContainingYourXML);
    var groups = doc1.Root.Elements().ToLookup(elt => elt.Attribute("PageID").Value);
    var unique = groups.AsEnumerable().Select(group => group.First());
    var doc2 = new XDocument(new XElement("root", unique));
    

    The explanation of this is that we are creating a lookup table on line 2, where elements containing the same value for PageID are grouped together. Given your example XML, it takes 4 <Page/> elements and creates 3 groups, with one group containing both PageID="1" elements.

    On line 3, we loop through the 3 groups and extract just the first XML element for one, and on line 4 we jam those 3 elements into a new document. The resulting XML is:

    <root>
      <Page PageID="**1**">
        <Para ParaID="1" />
      </Page>
      <Page PageID="**2**">
        <Para ParaID="**1**" />
      </Page>
      <Page PageID="**3**">
        <Para ParaID="**1**" />
      </Page>
    </root>
    

    Update: 2011/03/12

    The code below takes into account the requirement for paragraphs from duplicate instances of a page to be merged together in an auto-incrementing kind of way.

    The revised solution is pretty awful compared to the previous one, but messing around with the ParaID values (especially in the format they are in) was quite annoying. I’m not proud of this, but here it is:

    using System;
    using System.Linq;
    using System.Text.RegularExpressions;
    using System.Xml.Linq;
    
    namespace SO {
        class Program {
            static void Main(string[] args) {
                var doc1 = XDocument.Parse(xmlstr);
                var groups = doc1.Root.Elements().ToLookup(page => page.Attribute("PageID").Value);
                var doc2 = new XDocument(new XElement("root"));
    
                foreach (var group in groups) {
                    var firstpage = group.First();
                    var startindex = firstpage.Elements("Para").Last().Attribute("ParaID").Value;
                    var lastindex = int.Parse(Regex.Match(startindex, @"\d+").Value);
    
                    // Duplicate pages...
                    firstpage.Add(
                        group.Skip(1)
                             .SelectMany(page => page.Elements("Para"))
                             .Select(
                                 para => {
                                     para.Attribute("ParaID").Value = Regex.Replace(
                                         para.Attribute("ParaID").Value,
                                         @"\d+",
                                         m => (++lastindex).ToString()
                                     );
                                     return para;
                                 }
                             )
                    );
    
                    doc2.Root.Add(firstpage);
                }
    
                Console.WriteLine(doc2);
                Console.ReadKey(true);
            }
        }
    }
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have normally hand written xml like this: <tag><?= $value ?></tag> Having found tools
I have xml files I want to read in and store in the database.
I have XML with a value like the following: <products> <product id=1 name=All Products>
Greetings! If I have XML such as this: <Root> <AlphaSection> . . . </AlphaSection>
I have some XML which I want to extract via a javascript regular expression.
I have been creating multiple background threads to parse xml files and recreate new
I have xml where some of the element values are unicode characters. Is it
I have XML files in a directory that I wish to get over to
Is it possible to have XML-embedded JavaScript executed to assist in client-side (browser-based) XSL
So I have xml that looks like this: <todo-list> <id type=integer>#{id}</id> <name>#{name}</name> <description>#{description}</description> <project-id

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.