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 172027
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 11, 20262026-05-11T13:05:33+00:00 2026-05-11T13:05:33+00:00

The Title pretty much says it all. I have an XML document that I

  • 0

The Title pretty much says it all. I have an XML document that I am processing with XSLT …. but I don’t know how many columns (fields) that are in the XML document (therefore, obviously, I don’t know their names). How can I determine the number of ‘unknown’ fields there are? Also, how can I read the attributes, if any, for the unknown fields?

Example data ….

<Dataset>    <Row>        <UnknownCol1 Msg='HowDoIGetThisMsgAttribute?'/>        <UnknownCol2 />        <UnknownCol3 />    </Row> </Dataset> 
  • 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. 2026-05-11T13:05:34+00:00Added an answer on May 11, 2026 at 1:05 pm

    How can I determine the number of ‘unknown’ fields there are?

    This XPath expression:

    count(/*/*/*) 

    evalutes to the count of the elements, that a re children of the elements that are children of the top node of the XML document — exactly what is wanted in this case.

    If the 'Row' element can have children whose name does not start with ‘UnknownCol’,

    then this XPath expression provides the count of elements, whose name starts with ‘UnknownCol’, and that are children of elements that are children of the top element:

    count(/*/*/*[starts-with(name(), 'UnknownCol')]) 

    In case the top element may have other children than 'Row', then an XPath expression giving the required count is:

    count(/*/Row/*[starts-with(name(), 'UnknownCol')]) 

    Also, how can I read the attributes, if any, for the unknown fields?

    By knowing XPath 🙂

    /*/Row/*[starts-with(name(), 'UnknownCol')]/@* 

    selects all the attributes of all ‘UnknownCol'{String} elements

    This XPath expression gives us the number of these attributes:

      count(/*/Row/*[starts-with(name(), 'UnknownCol')]/@*) 

    This Xpath expression gives us the name of the k-th such attribute ($ind must be set to the number k):

    name( (/*/Row/*[starts-with(name(), 'UnknownCol')]/@*)[$ind] ) 

    And finally, this XPath expression produces the value of the k-th such attribute:

    string( (/*/Row/*[starts-with(name(), 'UnknownCol')]/@*)[$ind] ) 

    Edit: The OP commented that he completely doesn’t lnow the names of the children element.

    The fix is easy: simply remove the predicate from all expressions:

    count(/*/*/*)  count(/*/Row/*)   /*/Row/*/@*   count(/*/Row/*/@*)  name( (/*/Row/*/@*)[$ind] )  string( (/*/Row/*/@*)[$ind] ) 
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Ask A Question

Stats

  • Questions 142k
  • Answers 142k
  • Best Answers 0
  • User 1
  • Popular
  • Answers
  • Editorial Team

    How to approach applying for a job at a company ...

    • 7 Answers
  • Editorial Team

    How to handle personal stress caused by utterly incompetent and ...

    • 5 Answers
  • Editorial Team

    What is a programmer’s life like?

    • 5 Answers
  • Editorial Team
    Editorial Team added an answer You can either use array declaration or array literal (but… May 12, 2026 at 8:14 am
  • Editorial Team
    Editorial Team added an answer Look at Quartz. May 12, 2026 at 8:14 am
  • Editorial Team
    Editorial Team added an answer Here is a quick working example, i was messing around… May 12, 2026 at 8:14 am

Related Questions

The title pretty much says it all. When I'm doing some reflection through my
The title pretty much says it all, but to elaborate: If I build a
The title pretty much says it all. Some caveats are: I need to be
The title pretty much says it all. I'm using a TClientDataset to store an

Trending Tags

analytics british company computer developers django employee employer english facebook french google interview javascript language life php programmer programs salary

Top Members

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.