2

我的网站项目中有一个 xml 文件和一个 xslt 文件。当我运行该站点时,我需要从 xslt 调用 ac# 函数并更改 xml 文件中的值....下面是我的 xml 文件....我需要在其中添加一个文本(比如“先生”)通过 ac# 代码在每个名字的前面......添加后,它应该反映在 xml 文件中......另外,作为下一步,我需要通过另一个 c# 在 xml 文件中添加另一个节点(比如年龄)函数....请注意,应该从我的 xslt 文件中调用 c# 函数...。谁能帮我写一个简单的代码????

<?xml version="1.0" encoding="utf-8" ?>
<root>
  <employee>
    <firstname>Kaushal</firstname>
    <lastname>Parik</lastname>
  </employee>
  <employee>
    <firstname>Abhishek</firstname>
    <lastname>Swarnkar</lastname>
  </employee>
</root>
4

3 回答 3

8

是的,您可以从 .xsl 文件中调用 C# 函数。请参考以下代码。

这是您的输入 XML 文件:

<?xml version="1.0" encoding="utf-8" ?>
<?xml-stylesheet type="text/xsl" href="cdcatalog.xsl"?>
<root>
<employee>
  <firstname>Kaushal</firstname>
  <lastname>Parik</lastname>
</employee>
<employee>
  <firstname>Abhishek</firstname>
  <lastname>Swarnkar</lastname>
</employee>
</root>  

C# 类中的格式化函数如下所示:

    public class MyXslExtension
{
    public string FormatName(string name)
    {
        return "Mr. " + name;
    }
}  

应用以下 xsl:

<?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" exclude-result-prefixes="msxsl"
            xmlns:myUtils="pda:MyUtils">
<xsl:output method="xml" indent="yes"/>
<xsl:variable name="vQ">Mr. </xsl:variable>
<xsl:template match="@*|node()">
<xsl:copy>
  <xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="employee/firstname">
<xsl:element name="firstname">
  <xsl:value-of select="myUtils:FormatName(.)" />
</xsl:element>
</xsl:template>
</xsl:stylesheet>

而 C# Functin 调用 Formatting 函数是这样的:

private void button3_Click(object sender, EventArgs e)
    {
        XsltArgumentList arguments = new XsltArgumentList();
        arguments.AddExtensionObject("pda:MyUtils", new MyXslExtension());

        using (StreamWriter writer = new StreamWriter("books1.xml"))
        {
            XslCompiledTransform transform = new XslCompiledTransform();
            transform.Load("transform.xslt");
            transform.Transform("books.xml", arguments, writer);
        }
    }  

输出是:

<?xml version="1.0" encoding="utf-8"?>
<?xml-stylesheet type="text/xsl" href="cdcatalog.xsl"?>
<root>
<employee>
<firstname>Mr. Kaushal</firstname>
<lastname>Parik</lastname>
</employee>
<employee>
<firstname>Mr. Abhishek</firstname>
<lastname>Swarnkar</lastname>  
</employee>
</root>  

我已参考此链接来回答您的问题。

希望这会帮助你。
如果对你有用请标记+1....

于 2012-08-02T10:08:12.610 回答
1

将 XSL 样式表引用添加到您的 XML 文档,如下所示:

<?xml version="1.0" encoding="utf-8" ?>
<?xml-stylesheet type="text/xsl" href="cdcatalog.xsl"?>
<root>
  <employee>
    <firstname>Kaushal</firstname>
    <lastname>Parik</lastname>
  </employee>
  <employee>
    <firstname>Abhishek</firstname>
    <lastname>Swarnkar</lastname>
  </employee>
</root>    

或使用.NETXslTransform中的类来转换 XML 数据:XSLT

//Create the XslTransform object.
XslTransform xslt = new XslTransform();

//Load the stylesheet.
xslt.Load("output.xsl");

//Transform the file.
xslt.Transform("books.xml", "books.html");
于 2012-08-02T06:32:46.020 回答
0

应用以下 .xslt:

<?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" exclude-result-prefixes="msxsl">
<xsl:output method="xml" indent="yes"/>

<xsl:variable name="vQ">Mr. </xsl:variable>

<xsl:template match="@*|node()">
  <xsl:copy>
    <xsl:apply-templates select="@*|node()"/>
  </xsl:copy>
</xsl:template>

<xsl:template match="employee/firstname">
  <xsl:element name="firstname">
    <xsl:value-of  select="concat($vQ, .)"/>
  </xsl:element>
</xsl:template>

</xsl:stylesheet>

输入是:

<?xml version="1.0" encoding="utf-8" ?>
<?xml-stylesheet type="text/xsl" href="cdcatalog.xsl"?>
<root>
<employee>
  <firstname>Kaushal</firstname>
  <lastname>Parik</lastname>
</employee>
<employee>
  <firstname>Abhishek</firstname>
  <lastname>Swarnkar</lastname>
</employee>
</root>

输出是:

<?xml version="1.0" encoding="utf-8"?>
<?xml-stylesheet type="text/xsl" href="cdcatalog.xsl"?>
<root>
  <employee>
  <firstname>Mr. Kaushal</firstname>
  <lastname>Parik</lastname>
</employee>
<employee>
  <firstname>Mr. Abhishek</firstname>
  <lastname>Swarnkar</lastname>
</employee>
</root>  

C#函数是这样的:

private void button3_Click(object sender, EventArgs e)
    {
        XslTransform xslt = new XslTransform();  
        xslt.Load("transform.xslt");  
        xslt.Transform("books.xml", "books1.xml"); 
    }  

希望对你有帮助...

于 2012-08-02T09:29:56.997 回答