Transform 使用的一点心得。

Transform 使用的一点心得。
XSLT 文件:

如果在html代码之前有<xsl:value-of select=""/> 比如下面的XSLT代码:


<?xml version="1.0" encoding="UTF-8" ?>
<xsl-stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:fo="http://www.w3.org/1999/XSL/Format">
<xsl:template match="/">
<xsl:value-of select="/DearBookOrder/MainOrder/Email"/>
<xsl:value-of select="/DearBookOrder/MainOrder/EmailTopic"/>
<html>
<head>
<meta NAME="GENERATOR" Content="Microsoft Visual Studio 6.0"/>
</head>
...... 
</html>
</xsl-stylesheet>

它跟 XML 一起解析后的结果中,最前面部分就会变成:

<?xml version="1.0" encoding="utf-8"?>ghj1976@csdn.netDearBook 货到付款订单
<html xmlns:fo="http://www.w3.org/1999/XSL/Format">
<head><meta NAME="GENERATOR" Content="Microsoft Visual Studio 6.0" />
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
...
</head>
.....
</html>


.....

但是:

如果在html代码之前没有<xsl:value-of select=""/> 比如下面的XSLT代码:


<?xml version="1.0" encoding="UTF-8" ?>
<xsltylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:fo="http://www.w3.org/1999/XSL/Format">
<xsl:template match="/">
<html>
<xsl:value-of select="/DearBookOrder/MainOrder/Email"/>
<xsl:value-of select="/DearBookOrder/MainOrder/EmailTopic"/>
<head>
<meta NAME="GENERATOR" Content="Microsoft Visual Studio 6.0"/>
</head>
...... 
</html>
</xsl-stylesheet>

解析后的结果:

<html xmlns:fo="http://www.w3.org/1999/XSL/Format">ghj1976@csdn.netDearBook 货到付款订单
<head><META http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta NAME="GENERATOR" Content="Microsoft Visual Studio 6.0">
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
...
</head>
....
</html>

这样就没有: <?xml version="1.0" encoding="utf-8"?> 了。

 
这时候调用的代码为:

  private void button2_Click(object sender, System.EventArgs e)
  {
   string Savefile = @"C:/1.htm";
   string XmlFile = @"E:/MyWorks/test/Trans/TestWin/Order.xml";
   string XslFile = @"E:/MyWorks/test/Trans/TestWin/Order.xslt";
   if (File.Exists(Savefile))
   {
    File.Delete(Savefile);
   }
   FileStream fs = new FileStream(Savefile,FileMode.Create);
   XmlDocument xmlDoc = new XmlDocument();
   xmlDoc.Load(XmlFile);
   XPathNavigator nav = xmlDoc.DocumentElement.CreateNavigator();
   XslTransform xmlXsl = new XslTransform();
   xmlXsl.Load(XslFile);
   xmlXsl.Transform(nav,null,fs,null);
   xmlXsl = null;
   nav = null;
   xmlDoc = null;
   fs.Close();
   fs = null;
  }


后来根据 gooGiDEA 的意见,把代码改为:

  private void button1_Click(object sender, System.EventArgs e)
  {
   string Savefile = @"C:/1.htm";
   string XmlFile = @"E:/MyWorks/test/Trans/TestWin/Order.xml";
   string XslFile = @"E:/MyWorks/test/Trans/TestWin/Order.xslt";
   if (File.Exists(Savefile))
   {
    File.Delete(Savefile);
   }
   FileStream fs = new FileStream(Savefile,FileMode.Create);

   XmlTextWriter writer = new XmlTextWriter( fs, System.Text.Encoding.Default );
   writer.Formatting = Formatting.Indented;

   XmlDocument xmlDoc = new XmlDocument();
   xmlDoc.Load(XmlFile);
   XPathNavigator nav = xmlDoc.DocumentElement.CreateNavigator();
   XslTransform xmlXsl = new XslTransform();
   xmlXsl.Load(XslFile);
   xmlXsl.Transform(nav,null,writer,null);
   xmlXsl = null;
   nav = null;
   xmlDoc = null;
   fs.Close();
   fs = null;
  
  }

就没有这个问题了。

同样,思归提供的,再 XSLT 中增加
<xsl:output method="html" />
以上两个代码都是返回正确的。


原因:
老兄,你要是指定了xsl:output=Html,随便你怎么写都不会出来<?xml version="1.0" encoding="UTF-8" ?>。
实际上你这二个xslt为什么会这样在output的help里也可以找到说明:
The default for the method attribute is chosen as follows. If any of the following conditions are true, the default output method is "html":

The root node of the result tree has an element child.
The expanded-name of the first element child of the root node (that is, the document element) of the result tree has local part "html" (in any combination of uppercase and lowercase) and a null namespace URI.
Any text nodes preceding the first element child of the root node of the result tree contain only white space characters.
Otherwise, the default output method is "xml".
Zee 提供的。

具体讨论过程看:


http://blog.joycode.com/ghj/posts/4080.aspx

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Transform是一种基于矩阵运算的机器学习算法,主要用于特征转换和数据变换。它可以将输入数据转换为另一种形式的特征表示,以便更好地适应机器学习模型的学习和预测。 使用Transform的方法通常包括以下步骤: 1. 导入必要的库和模块:在使用Transform之前,需要导入相应的库和模块,例如NumPy、Pandas、Scikit-learn等。 2. 准备数据:将需要使用Transform的数据准备好,包括数据集、标签等。 3. 定义Transform模型:根据需要使用Transform的任务,定义相应的Transform模型。通常需要指定输入特征的维度、输出特征的维度以及变换的算法和参数等。 4. 训练Transform模型:使用训练数据对Transform模型进行训练,可以通过交叉验证等方法优化模型的性能。 5. 预测和评估:使用训练好的Transform模型对测试数据进行预测,并评估模型的性能。 下面是一个简单的示例代码,演示如何使用Scikit-learn库Transform算法进行特征转换: ```python from sklearn.preprocessing import StandardScaler import numpy as np # 准备数据 X = np.array([[1, 2], [3, 4], [5, 6]]) y = np.array([0, 1, 2]) # 定义标准化变换模型 scaler = StandardScaler() # 训练标准化变换模型 X_transformed = scaler.fit_transform(X) # 对测试数据进行预测并评估模型性能 X_test = np.array([[7, 8], [9, 10]]) predictions = scaler.predict(X_test) print(predictions) ``` 在这个示例,我们使用了Scikit-learn库的StandardScaler算法对数据进行标准化变换。标准化变换是一种常见的特征转换方法,用于将数据的均值和方差归一化为零和一,从而减少数据之间的尺度差异。在这个示例,我们使用训练好的标准化变换模型对测试数据进行预测,并打印出预测结果。 需要注意的是,Transform算法有很多种,不同的Transform算法适用于不同的任务和数据集。因此,在使用Transform之前,需要根据具体任务和数据集选择合适的Transform算法,并进行相应的参数调整和优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值