通过调用XSLT C#的功能改变的xml文件(Alter xml file by calling a

2019-07-30 17:58发布

我有一个XML文件,并在我的网站项目的XSLT文件。 当我运行的网站,我需要从XSLT调用C#功能和改变的XML文件中的值....下面给出的是我的XML文件....我需要添加一个文本(比如“先生”)在通过C#代码每个名字前面加....之后,它应该反映在XML文件....此外,作为下一步,我需要通过另一个C#添加另一个节点的XML文件(比如年龄)功能....请注意,C#函数应该从我的XSLT文件被称为....谁能帮我这个简单的代码????

<?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>

Answer 1:

是的,你可以调用从的.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#的载体作用调用格式化函数是这样的:

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,如果它是对你有用....



Answer 2:

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>    

或使用XslTransform类使用来将XML数据XSLT从.NET:

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

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

//Transform the file.
xslt.Transform("books.xml", "books.html");


Answer 3:

适用以下.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"); 
    }  

希望对你有帮助...



文章来源: Alter xml file by calling a C# function in xslt