如何使用Powershell在XML中打印尖括号

时间:2019-04-02 18:32:53

标签: xml powershell powershell-v5.0 powershell-v5.1

我想在powershell中打印尖括号(<,>),但它分别打印到>和<。有什么办法可以打印这些符号。

我使用\来克服括号的转义属性以及单个反逗号,但结果仍然相同。

$xml = [xml](Get-Content -Path C:\Users\Desktop\new.xml)
$xml.Deploy.app="$<abc\bc>"
$xml.Save("C:\Users\Desktop\new.xml")

我希望输出是

<?xml version="1.0"?> 
<Deploy>
  <app><abc\bc></app>
</Deploy>

但可以打印

<?xml version="1.0"?>
<Deploy>
  <app>&lt;abc\bc&gt;</app>
</Deploy>

提前谢谢!

2 个答案:

答案 0 :(得分:2)

XML需要替换5个字符,因为它们在XML中具有特殊含义。这些字符是<>&'" 在这里,您不能简单地在这些字符前面加上一些转义字符(例如反斜杠),而是需要将它们转换为已命名或编号的entities

您已经注意到,这种转换会在[xml]中自动发生,但是如果需要,还有多种方法可以手动进行:

$str = "$<abc\bc>"

1):使用字符串.Replace()方法:

$str.Replace("&", "&amp;").Replace("'", "&apos;").Replace('"', "&quot;").Replace("<", "&lt;").Replace(">", "&gt;")

2):使用.Net System.Security:

 Add-Type -AssemblyName System.Security
 [System.Security.SecurityElement]::Escape($str)

3)使用System.Xml.XmlDocument:

[xml]$doc = New-Object System.Xml.XmlDocument
$node = $doc.CreateElement("root")
$node.InnerText = $str
$node.InnerXml

4):使用正则表达式:

$str -ireplace '&#34;|&#x(?:00)?22;|"', '&quot;' `
     -ireplace "&#39;|&#x(?:00)?27;|'", '&apos;' `
     -ireplace '&#60;|&#x(?:00)?3C;|<', '&lt;'   `
     -ireplace '&#62;|&#x(?:00)?3E;|>', '&gt;'   `
     -ireplace '&#38;|&#x(?:00)?26;|&(?!(?:[a-z]+|#[0-9]+|#x[0-9a-f]+);)', '&amp;'

以上所有内容均会将XML特殊字符转换为实体,因此结果将如下所示:

  

$&lt;abc\bc&gt;


如果您绝对不希望将XML特殊字符转换为实体,则只有AFAIK选项可以将值设置为CDATA section,这会将您的字符串包装在<![CDATA[中和]]>]。 要在您的示例中使用它,请将行$xml.Deploy.app="$<abc\bc>"更改为此:

$xml['Deploy']['app'].AppendChild($xml.CreateCDataSection("$<abc\bc>")) | Out-Null

现在它将打印:

<?xml version="1.0"?>
<Deploy>
  <app><![CDATA[$<abc\bc>]]></app>
</Deploy>

要以字符串形式读取此CDATA值,可以执行$value = $xml.Deploy.app.InnerText$value = $xml.Deploy.app.'#cdata-section'

希望能解释

答案 1 :(得分:0)

这就是XML的工作方式。小于和大于字符是保留/特殊字符。当值包含它们时,它将把它们转换为它们的转义格式&lt;&gt;。您期望输出的是无效的XML。