我有下面的函数可以创建一个 HTML 表,但是我希望我的表中的值指向超链接。
Function MyFunction{
clear-host
$item=$null
$hash = $null #hashTable
$hash =@{"Google.com" = "www.google.com"; "Yahoo" = "www.yahoo.com";"My Directory" ="C:\Users\Public\Favorites" ;"MSN" = "www.msn.com"}
ForEach($item in @($hash.KEYS.GetEnumerator())){
$hash | Sort-Object -Property name
}
$hash.GetEnumerator() | sort -Property Name |Select-Object Name, Value | ConvertTo-HTML | Out-File .\Test.html
}
MyFunction
最佳答案
在我们开始之前的小注意事项:ForEach
似乎毫无意义,因为它只是为表格中的每个元素输出排序后的表格。所以它被删除了。ConvertTo-HTML
就其本身而言,非常适合使用 PowerShell 对象制作表格,但我们需要的是超链接。 ConvertTo-HTML
确实支持计算属性,因此起初制作格式化的超链接似乎很容易。
ConvertTo-HTML -Property *,@{Label="Link";Expression={"<a href='$($_.Value)'>$($_.Name)</a>"}}
与此有关的小问题是
ConvertTo-Html
对发送给它的字符串进行一些转换,这混淆了我们的意图。查看创建的输出文件,我们看到 Yahoo 链接的以下内容:<td><a href='www.yahoo.com'>Yahoo</a></td>
ConvertTo-Html
使我们的文本浏览器友好,这通常很好,但现在阻碍了我们。阅读来自 PowerShell Magazine 的博客通过在将 html 发送到文件之前对其进行解码来解决此问题。Function MyFunction{
clear-host
$hash = @{"Google.com" = "www.google.com"; "Yahoo" = "www.yahoo.com";"My Directory" ="C:\Users\Public\Favorites" ;"MSN" = "www.msn.com"}
$hash.GetEnumerator() | sort -Property Name | Select-Object Name, Value |
ConvertTo-HTML -Property *,@{Label="Link";Expression={"<a href='$($_.Value)'>$($_.Name)</a>"}}
}
$html = MyFunction
Add-Type -AssemblyName System.Web
[System.Web.HttpUtility]::HtmlDecode($html) | Out-File C:\temp\test.html
使用
[System.Web.HttpUtility]::HtmlDecode
转换类似 <
的值回到我们希望他们成为的样子。看看输出去看看之前是否有人问过这个问题,并且有类似的答案:How to generate hyperlinks to .htm files in a directory in Powershell? .它以不同的方式处理,所以我不知道将其标记为重复。
关于powershell - 使用 ConvertTo-HTML 将 URL 列表转换为可点击的 HTML 链接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27652761/