XML Editor
Sign up for a WebBoard account Sign Up Keyword Search Search More Options... Options
Chat Rooms Chat Help Help News News Log in to WebBoard Log in Not Logged in
Conferences Close Tree View
+ Stylus Studio Feature Requests (1192)
- Stylus Studio Technical Forum (14621)
-> + Error in Stylus Studio - canno... (2)
-> + Saxon Assign (2)
-> - License Authentication Failed (1)
-> + Stylus Studio 2007 Download (2)
-> + EDI to XML validation (2)
-> + Reports: can't remove "undead"... (3)
-> + Document Wizard Incomplete (6)
-> + Opening xml converter (4)
-> + Node depth limit with MySQL? (5)
-> + Basics (2)
-> - Node depth limit with MySQL? (1)
-> + Creating an XML Schema from a ... (4)
-> - Issue with XSD (1)
-> + XSL-FO and Apache FOP (2)
-> + How Come Stylus Studio Fails T... (6)
-> + no suitable driver (8)
-> + 211,19: no declaration found f... (6)
-> - Validate HEX (1)
-> + Crashing when connected to dat... (3)
-> - Interface with quickbooks (1)
-> - CDATA control (1)
-> + [resolved] Namespace (and pref... (5)
-> - Hiding and Revealing Child Nod... (1)
-> + Cannot see values in Watch whe... (4)
-> - Help with CSV to XML and Regio... (1)
-> + How do I verify "opt=yes" URI ... (4)
-> - Stylus Studio claims xsd is in... (1)
-> + Can a generated XSD be used in... (4)
-> + I am not a developer I'm just ... (2)
-> + Stylus crash when deleting dat... (6)
-> - Preserving Structure (1)
-> - Preserving Structure (1)
-> - HL7 ORU group tags (1)
-> + Fixed Length Record Layout to ... (2)
-> + WebService Connect (6)
-> - WebService conection problems (1)
-> + Could not detect EDI dialect a... (3)
-> + I am a bookkeeper not a progra... (2)
-> + fatal error (4)
-> - Saxon linebreak (1)
-> + task scheduler (2)
-> - Number of Elements in Grid vie... (1)
-> + Compile Java (2)
-> + What happened to the EDI Wizar... (15)
-> + setting Transformer for java b... (3)
-> + XML Schema Documentation Gener... (3)
-> + EANCOM xsd-files (4)
-> + Failure of CDATA converting pr... (4)
-> + XML File created from text fil... (3)
-> + After purchase AND activation ... (2)
-> + XQuery Format of XML code snip... (4)
-> + Error during conversion (9)
-> - testing for empty nodes (1)
-> + edi converter - java fails (10)
-> + ddtek:serialize (3)
-> - File explorer view (1)
-> - Java Extension Functions (1)
-> + err:FODC0004 (18)
-> - Removing Attributes when Null (1)
-> + CDATA preservation (6)
-> + Help converting xml report to ... (2)
-> + Converting text to XML issue (3)
-> - example not working (1)
-> + XML Editing (2)
-> + Multiple EDI messages within s... (5)
-> + Mapping RDBMS and XML Schema t... (2)
-> + MySQL Database importing (2)
-> + XSD validation using XSV fails... (3)
-> + Is this really well-formed? (3)
-> + HL7 EDI to XML problems -'ORU_... (11)
-> + How do I modify the Xquery to ... (2)
-> + XML mapping difficulty (3)
-> + XLST Conversion (2)
-> + HTML TO XSL Conversion (2)
-> - Convert an EBCDIC file to XML (1)
-> + License Manager still indicate... (4)
-> + Still sometimes getting beat b... (2)
-> + What versions of MySQL are sup... (5)
-> - External XSLT processor proble... (1)
-> + DDEE0082 Erro Internal system ... (6)
-> + Calling function from .NET C# (2)
-> + Stylus studio projects bound t... (3)
-> + Report Designer mistakenly gen... (3)
-> + Choose Nodes in pipelines (3)
-> + Custom external processor and ... (2)
-> + predefined (4)
-> + translate function in java (2)
-> + XMLPipeline trouble in Linux (7)
-> + Converting Custom EDI Message ... (2)
-> + tab delimetered file with vari... (2)
-> + XML validation with XSD (2)
-> + Missing documentation: SSL_Cer... (2)
-> + Parse Xcel input file which is... (2)
-> + XML Publisher post processors (2)
-> + Alignment of table items in XM... (2)
-> + XML to PDF using XML Publisher (2)
-> + Blurry Background image / Vect... (4)
-> + URIResolver error on command l... (2)
-> + stylus studio - the (3)
-> + problem with omit from output ... (3)
-- Previous [481-500] [501-520] [521-540] Next
+ Website Feedback (249)
+ XSLT Help and Discussion (7625)
+ XQuery Help and Discussion (2017)
+ Stylus Studio FAQs (159)
+ Stylus Studio Code Samples & Utilities (364)
+ Stylus Studio Announcements (113)
Topic  
Postnext
Yama KamyarSubject: replace the hex to space
Author: Yama Kamyar
Date: 23 Mar 2005 02:49 PM
Hi,

What can I use to parse the header space:

An_x0020_Int_x0020_Key

Replace _x0020_ to <<space>>

during the transformation? Is this possible?

Postnext
Ivan PedruzziSubject: replace the hex to space
Author: Ivan Pedruzzi
Date: 23 Mar 2005 10:37 PM


Please describe your problem more clearly

If An_x0020_Int_x0020_Key is an XML element name the answer is no you can't use space

Ivan



Postnext
Yama KamyarSubject: replace the hex to space
Author: Yama Kamyar
Date: 24 Mar 2005 12:07 AM
Hi,

What I meant is how can I output this in HTML version by replacing the hex _x0020_ by spaces. Here is the XML file:

<ExampleDataSet xmlns="http://tempuri.org/DataSet1.xsd">
<ExampleDataTable>
<An_x0020_Int_x0020_Key>1</An_x0020_Int_x0020_Key>
<A_x0020_String>Column 1</A_x0020_String>
<A_x0020_DateTime>2005-03-24T00:00:00.0000000-08:00</A_x0020_DateTime>
<A_x0020_Category>Category 1</A_x0020_Category>
<A_x0020_Random>27</A_x0020_Random>
</ExampleDataTable>
<ExampleDataTable>
<An_x0020_Int_x0020_Key>2</An_x0020_Int_x0020_Key>
<A_x0020_String>Column 2</A_x0020_String>
<A_x0020_DateTime>2005-03-25T00:00:00.0000000-08:00</A_x0020_DateTime>
<A_x0020_Category>Category 1</A_x0020_Category>
<A_x0020_Random>36</A_x0020_Random>
</ExampleDataTable>
<ExampleDataTable>
<An_x0020_Int_x0020_Key>3</An_x0020_Int_x0020_Key>
<A_x0020_String>Column 3</A_x0020_String>
<A_x0020_DateTime>2005-03-26T00:00:00.0000000-08:00</A_x0020_DateTime>
<A_x0020_Category>Category 1</A_x0020_Category>
<A_x0020_Random>57</A_x0020_Random>
</ExampleDataTable>
</ExampleDataSet>


This "An_x0020_Int_x0020_Key" should be "An Int Key"
This "A_x0020_String" should be "A String"

This is the way .NET maps the column names unfortunately.

So if I were to write a XSLT to transform this to a simple HTML output with a table containing my ExampleDataSet table how would I do this as well as get rid of the unreadable column names contain the _x0020_ instead of the space?

Thanks a lot,

Yama

Postnext
Ivan PedruzziSubject: replace the hex to space
Author: Ivan Pedruzzi
Date: 24 Mar 2005 12:51 AM

I see now.

the following example (XSLT 2) display a table using the element name and the value

<?xml version='1.0' encoding='utf-8'?>
<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:a="http://tempuri.org/DataSet1.xsd" exclude-result-prefixes="a">
<xsl:output method="html"/>

<xsl:template match="/">
<html><head></head>
<body>
<table border="1">
<tbody>
<xsl:for-each select="a:ExampleDataSet/a:ExampleDataTable/*">
<tr>
<td width="50%">
<xsl:value-of select="replace(local-name(), '_x0020_', ' ')"/>
</td>
<td width="50%"><xsl:value-of select="."/></td>
</tr>
</xsl:for-each>
</tbody>
</table>
</body>
</html>
</xsl:template>

</xsl:stylesheet>

Postnext
Yama KamyarSubject: replace the hex to space
Author: Yama Kamyar
Date: 24 Mar 2005 03:47 AM
Hi,

Thank you for replying!

I tested this but I got the following error:

--------------------------------
'replace()' is an unknown XSLT function.
Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code.

Exception Details: System.Xml.Xsl.XsltException: 'replace()' is an unknown XSLT function.

Source Error:


Line 80:
Line 81: //Transform the data and send the output to the console.
Line 82: xslt.Transform(mydata, null, writer, null);
Line 83:
--------------------------------

I am not sure if .NET version 1.1 supports XSL version 2.0.. Does it? Am I doing something wrong?

Yama


Postnext
Yama KamyarSubject: replace the hex to space
Author: Yama Kamyar
Date: 24 Mar 2005 01:14 PM
Hi,

To ALL interested here is how regexp work with .NET. This XSLT will create a comma delimited file output of your XML




<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:msxsl="urn:schemas-microsoft-com:xslt" xmlns:regExp="http://exslt.org/regular-expressions" extension-element-prefixes="regExp msxsl">
<msxsl:script language="JavaScript" implements-prefix="regExp">
<![CDATA[
/**
<doc:module date="2001-06-12">
<doc:module>exslt:regular-expressions</doc:module>
<doc:name>regExp</doc:name>
<doc:version>1.0</doc:version>
<doc:language>exslt:javascript</doc:language>
<doc:meta>
<doc:author email="chris@bayes.co.uk" url="http://www.bayes.co.uk">Chris Bayes</doc:author>
<doc:summary>Implementation of EXSLT - RegExp (http://www.exslt.org/regExp)</doc:summary>
<doc:todo></doc:todo>
</doc:meta>
</doc:module>
**/
/**
<doc:function date="2001-06-12">
<doc:name>replace</doc:name>
<doc:version>1.0</doc:version>
<doc:return type="string" />
<doc:args>
<doc:arg name="context" type="context" default="null" optional="no"></doc:arg>
<doc:arg name="regExp" type="string" default="''" optional="no"></doc:arg>
<doc:arg name="flags" type="string" default="''" optional="no"></doc:arg>
<doc:arg name="repStr" type="string" default="''" optional="no"></doc:arg>
</doc:args>
</doc:function>
**/
/**


Function Syntax

string regexp:replace(string, string, string, string)
The regexp:replace function replaces the parts of a string that match a regular expression with another string.

The first argument is the string to be matched and replaced. The second argument is a regular expression that follows the Javascript regular expression syntax. The fourth argument is the string to replace the matched parts of the string.

The third argument is a string consisting of character flags to be used by the match. If a character is present then that flag is true. The flags are:

g: global replace - all occurrences of the regular expression in the string are replaced. If this character is not present, then only the first occurrence of the regular expression is replaced.
i: case insensitive - the regular expression is treated as case insensitive. If this character is not present, then the regular expression is case sensitive.


FunctionThe following example shows how to use the regexp:replace function:

Source
<a>
<c>Is this EXSLT? No. no</c>
</a>
Stylesheet
<xsl:template match="a">
<xsl:apply-templates />
</xsl:template>
<xsl:template match="*">
<out>
<xsl:value-of select="." />
-
<xsl:value-of select="regexp:replace(string(.), 'no', 'g', 'yes!!!')" />
<xsl:value-of select="regexp:replace(string(.), 'no', 'gi', 'yes!!!')" />
<xsl:apply-templates select="*" />
</out>
</xsl:template>
Result
<out>Is this EXSLT? No. no -
Is this EXSLT? No. yes!!!Is this EXSLT? yes!!!. yes!!!</out>
**/
/**
MORE INFORMATION: http://www.exslt.org/regexp/functions/replace/
**/
/**
Author: Yama Kamyar
URL: http://blog.yamabiz.com/ (coming soon)
**/

function replace(ctx, re, flags, repStr){
var ipString = "";
if (typeof(ctx) == "object"){
if (ctx.length){
for (var i=0; i < 1; i++){
var ctxN = ctx.item(i);
if (ctxN.nodeType == 1){
ipString += _wander(ctxN);
}
if (ctxN.nodeType == 2){
ipString += ctxN.nodeValue;
}
}
}else{
return '';
}
}else{
ipString = ctx;
}
var re = new RegExp(re, flags);
return ipString.replace(re, repStr);
}
function _wander(ctx){
var retStr = "";
for (var i=0; i < ctx.childNodes.length; i++){
var ctxN = ctx.childNodes[i];
switch(ctxN.nodeType){
case 1:
retStr += _wander(ctxN);
break;
case 3:
retStr += ctxN.nodeValue;
break;
default:
break;
}
}
return retStr;
}


]]>
</msxsl:script>

<xsl:output method="text" omit-xml-declaration="yes" indent="yes" encoding="utf-8"/>
<xsl:template match="/">
<xsl:for-each select="*/*">
<xsl:if test="position()=1">
<xsl:for-each select="*"><xsl:value-of select="regExp:replace(name(current()), '_x0020_','gi',' ')"/><xsl:if test="count(following-sibling::*) != 0">,</xsl:if></xsl:for-each>
<xsl:text>&#13;&#10;</xsl:text>
</xsl:if>
</xsl:for-each>
<xsl:for-each select="./*">
<xsl:apply-templates />
</xsl:for-each>
</xsl:template>
<xsl:template match="*">
<xsl:for-each select="*"><xsl:value-of select="text()"/><xsl:if test="count(following-sibling::*) != 0">,</xsl:if></xsl:for-each>
<xsl:text>&#13;&#10;</xsl:text>
</xsl:template>
</xsl:stylesheet>



Hope this will help!

~yamazed

Posttop
Yama KamyarSubject: replace the hex to space
Author: Yama Kamyar
Date: 24 Mar 2005 01:31 PM
Hi,

To ALL interested here is how regexp work with .NET. This XSLT will create a comma delimited file output of your XML




<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:msxsl="urn:schemas-microsoft-com:xslt" xmlns:regExp="http://exslt.org/regular-expressions" extension-element-prefixes="regExp msxsl">
<msxsl:script language="JavaScript" implements-prefix="regExp">
<![CDATA[
/**
<doc:module date="2001-06-12">
<doc:module>exslt:regular-expressions</doc:module>
<doc:name>regExp</doc:name>
<doc:version>1.0</doc:version>
<doc:language>exslt:javascript</doc:language>
<doc:meta>
<doc:author email="chris@bayes.co.uk" url="http://www.bayes.co.uk">Chris Bayes</doc:author>
<doc:summary>Implementation of EXSLT - RegExp (http://www.exslt.org/regExp)</doc:summary>
<doc:todo></doc:todo>
</doc:meta>
</doc:module>
**/
/**
<doc:function date="2001-06-12">
<doc:name>replace</doc:name>
<doc:version>1.0</doc:version>
<doc:return type="string" />
<doc:args>
<doc:arg name="context" type="context" default="null" optional="no"></doc:arg>
<doc:arg name="regExp" type="string" default="''" optional="no"></doc:arg>
<doc:arg name="flags" type="string" default="''" optional="no"></doc:arg>
<doc:arg name="repStr" type="string" default="''" optional="no"></doc:arg>
</doc:args>
</doc:function>
**/
/**


Function Syntax

string regexp:replace(string, string, string, string)
The regexp:replace function replaces the parts of a string that match a regular expression with another string.

The first argument is the string to be matched and replaced. The second argument is a regular expression that follows the Javascript regular expression syntax. The fourth argument is the string to replace the matched parts of the string.

The third argument is a string consisting of character flags to be used by the match. If a character is present then that flag is true. The flags are:

g: global replace - all occurrences of the regular expression in the string are replaced. If this character is not present, then only the first occurrence of the regular expression is replaced.
i: case insensitive - the regular expression is treated as case insensitive. If this character is not present, then the regular expression is case sensitive.


FunctionThe following example shows how to use the regexp:replace function:

Source
<a>
<c>Is this EXSLT? No. no</c>
</a>
Stylesheet
<xsl:template match="a">
<xsl:apply-templates />
</xsl:template>
<xsl:template match="*">
<out>
<xsl:value-of select="." />
-
<xsl:value-of select="regexp:replace(string(.), 'no', 'g', 'yes!!!')" />
<xsl:value-of select="regexp:replace(string(.), 'no', 'gi', 'yes!!!')" />
<xsl:apply-templates select="*" />
</out>
</xsl:template>
Result
<out>Is this EXSLT? No. no -
Is this EXSLT? No. yes!!!Is this EXSLT? yes!!!. yes!!!</out>
**/
/**
MORE INFORMATION: http://www.exslt.org/regexp/functions/replace/
**/
/**
Author: Yama Kamyar
URL: http://blog.yamabiz.com/ (coming soon)
**/

function replace(ctx, re, flags, repStr){
var ipString = "";
if (typeof(ctx) == "object"){
if (ctx.length){
for (var i=0; i < 1; i++){
var ctxN = ctx.item(i);
if (ctxN.nodeType == 1){
ipString += _wander(ctxN);
}
if (ctxN.nodeType == 2){
ipString += ctxN.nodeValue;
}
}
}else{
return '';
}
}else{
ipString = ctx;
}
var re = new RegExp(re, flags);
return ipString.replace(re, repStr);
}
function _wander(ctx){
var retStr = "";
for (var i=0; i < ctx.childNodes.length; i++){
var ctxN = ctx.childNodes[i];
switch(ctxN.nodeType){
case 1:
retStr += _wander(ctxN);
break;
case 3:
retStr += ctxN.nodeValue;
break;
default:
break;
}
}
return retStr;
}


]]>
</msxsl:script>

<xsl:output method="text" omit-xml-declaration="yes" indent="yes" encoding="utf-8"/>
<xsl:template match="/">
<xsl:for-each select="*/*">
<xsl:if test="position()=1">
<xsl:for-each select="*"><xsl:value-of select="regExp:replace(name(current()), '_x0020_','gi',' ')"/><xsl:if test="count(following-sibling::*) != 0">,</xsl:if></xsl:for-each>
<xsl:text>&#13;&#10;</xsl:text>
</xsl:if>
</xsl:for-each>
<xsl:for-each select="./*">
<xsl:apply-templates />
</xsl:for-each>
</xsl:template>
<xsl:template match="*">
<xsl:for-each select="*"><xsl:value-of select="text()"/><xsl:if test="count(following-sibling::*) != 0">,</xsl:if></xsl:for-each>
<xsl:text>&#13;&#10;</xsl:text>
</xsl:template>
</xsl:stylesheet>



Hope this will help!

~yamazed

   
Download A Free Trial of Stylus Studio 6 XML Professional Edition Today! Powered by Stylus Studio, the world's leading XML IDE for XML, XSLT, XQuery, XML Schema, DTD, XPath, WSDL, XHTML, SQL/XML, and XML Mapping!  
go

Log In Options

Site Map | Privacy Policy | Terms of Use | Trademarks
Stylus Scoop XML Newsletter:
W3C Member
Stylus Studio® and DataDirect XQuery ™are from DataDirect Technologies, is a registered trademark of Progress Software Corporation, in the U.S. and other countries. © 2004-2016 All Rights Reserved.