我的网站项目中有一个 xml 文件和一个 xslt 文件。当我运行该站点时,我需要从 xslt 调用一个 c# 函数并更改 xml 文件中的值....下面是我的 xml 文件....我需要添加一个文本(比如“先生”)通过 c# 代码在每个名字前面....添加后,它应该反射(reflect)在 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>
最佳答案
是的,您可以从 .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>
我提到了this link回答你的问题。
希望对您有所帮助。
如果对您有用,请标记+1....
关于c# - 通过在 xslt 中调用 C# 函数来更改 xml 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11772063/