使用PowerShell将XML转换为HTML
我有一个XML文件:使用PowerShell将XML转换为HTML,xml,powershell,Xml,Powershell,我有一个XML文件: <?xml version="1.0" encoding="utf-8"?> <?xml-stylesheet type='text/xsl' href='file:///C:/Program%20Files/Application/log_format.xsl'?> <!DOCTYPE log [<!ENTITY data SYSTEM 'data/20130408.dat'>]> <log xmlns="runtim
<?xml version="1.0" encoding="utf-8"?>
<?xml-stylesheet type='text/xsl' href='file:///C:/Program%20Files/Application/log_format.xsl'?>
<!DOCTYPE log [<!ENTITY data SYSTEM 'data/20130408.dat'>]>
<log xmlns="runtime:log">&data;</log>
&数据;
xsl文件将其转换为HTML。我无法在IE中打开文件并查看预期结果。我想通过PowerShell脚本将其转换为纯HTML。我该怎么做呢?有一个转换Xml
,它将对Xml进行XSL转换。如果生成的文件不是有效的HTML,则需要处理XSL文件 这有一个应该可以工作的代码片段。它使用System.Xml.Xsl.xslcomiledTransform
.NET类进行Xsl转换。其余的只是获取输入和显示输出
这最初是一个注释,但我想我会将其作为一个答案,以便其他正在搜索解决方案的人更方便。如果您希望返回xml对象,而不是将输出写入文件,以便可以执行更多的在线活动。这会奏效的。此外,我将处理器的创建拆分为一个单独的函数,这样您就可以创建一次并重新使用它,这对内存更为友好
function Invoke-TransformXML($path,$styleSheetPath,$output,$parameters, $compiledtransform)
{
if( ! (test-path $path )) { Throw"XML input file not found: $path"}
$path = resolve-path $path
if ( ! (Test-Path $compiledtransform))
{
if( ! ($compiledtransform.GetType() -eq [System.Xml.Xsl.XslCompiledTransform] ))
{
$ctType = $compiledtransform.GetType() ;
Throw "Compiled transform is wrong type: $ctType"
}
else
{
$xslt = $compiledtransform
}
}
if (($compiledtransform -eq $null) )
{
if( ! (test-path $styleSheetPath ) ) { Throw"XSL template file not found: $styleSheetPath"}
$styleSheetPath = Resolve-Path $styleSheetPath
$xslt = Get-CompiledTransform $styleSheetPath
}
$transformed = New-Object System.IO.MemoryStream
try
{
$xslt.Transform([string]$path, [System.Xml.Xsl.XsltArgumentList]$arglist, [System.IO.Stream]$transformed)
$transformed.Position = 0
#$reader = New-Object System.Xml.XmlTextReader($ms)
$outdoc = New-Object System.Xml.XmlDocument
$outdoc.Load($transformed)
# close stream, we are done with it
$transformed.Close()
return $outdoc
} Finally {
$transformed.Close()
}
}
function Get-CompiledTransform($styleSheetPath)
{
if( ! (test-path $styleSheetPath ) ) { Throw"XSL template file not found: $styleSheetPath"}
$styleSheetPath = Resolve-Path $styleSheetPath
if( [System.Diagnostics.Debugger]::IsAttached )
{
$xslt = New-Object System.Xml.Xsl.XslCompiledTransform( $true )
}
else
{
$xslt = New-Object System.Xml.Xsl.XslCompiledTransform( $false )
}
$arglist = new-object System.Xml.Xsl.XsltArgumentList
foreach( $param in $parms )
{
if ($parms.Name)
{
$paramName = $parms.Name
$paramNamespaceUri = $parms.NamespaceUri
$paramValue = $parms.Value
$arglist.AddParam($paramName, $paramNamespaceUri, $paramValue)
}
}
$xsltSettings = New-Object System.Xml.Xsl.XsltSettings($false,$true)
$xslt.Load($styleSheetPath, $xsltSettings, (New-Object System.Xml.XmlUrlResolver))
return $xslt
}
经过一些解释,上述评论应该是一个答案;可能是公认的答案(因为它不依赖于加载额外的模块)。完美的解决方案,没有代码,只是指向正确的方向:)