- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个包含 PowerShell 对象表示法的文本文件 (PsonObjects.txt),如下所示:
@{Computer=Dektop123; ServiceA=Running; ServiceB=Running; RunspaceId=1a-1b}
@{Computer=Dektop456; ServiceA=Stopped; ServiceB=Stopped; RunspaceId=2b-2c}
@{Computer=Laptop123; ServiceA=NotFound; ServiceB=Running; RunspaceId=3c-4c}
@{ServiceA=NotFound; Computer=Laptop456; ServiceB=Running; RunspaceId=4d-5d}
我想将此 Pson 文件转换为 Csv 文件,但一直无法成功。
问题是有时一个对象的属性顺序与前一个对象的顺序不同。就像上面例子中的最后一行。因此,简单地将分号 (';') 转换为逗号 (',') 并删除 '@{}' 字符不会生成正确排序的 Csv 文件。
有没有一种简单的方法可以将此 Pson(Powershell 对象表示法)文件转换为 CSV 文件?
我尝试了几种不同的方法,但我一直在我的 CSV 输出文件中获取字符串的长度或哈希表输出(IsReadOnly、IsFixedSize、IsSychronized、keys、Values、SyncRoot、Count)。
非工作代码:
$inputFile = PsonObjects.txt
$CsvFileName = CsvOutput.csv
foreach($line in (Get-Contnet $inputfile)){
$newline = $line | convertFrom-StringData
$newline | Export-CSV $CsvFileName -Append
}
感谢任何有关此问题的帮助或建议。
最佳答案
ConvertFrom-StringData
输出一个未排序的Hashtable
,其中元素可以是任意顺序,所以在这里没有用。
这是一个可能的解决方案,使用 -split
运算符和排序步骤,使用 ordered Hashtable
:
$inputFile = 'PsonObjects.txt'
$csvFileName = 'CsvOutput.csv'
# The order of columns in the output CSV
$keyOrder = 'Computer','ServiceA','ServiceB','RunspaceId'
Get-Content $inputfile | ForEach-Object {
$line = $_.Trim('@{}') # Remove unwanted characters from current line
# First parse the current line into an unordered hashtable
$ht = @{}
foreach( $field in $line -split '; ' ) {
$key, $value = $field -split '='
$ht[ $key ] = $value
}
# Using the order specified by $keyOrder, create an ordered hashtable
$orderedHt = [ordered] @{}
foreach( $key in $keyOrder ) {
$orderedHt[ $key ] = $ht[ $key ]
}
[PSCustomObject] $orderedHt # Convert hashtable to custom object
} | Export-Csv $csvFileName
输出:
"Computer","ServiceA","ServiceB","RunspaceId"
"Dektop123","Running","Running","1a-1b"
"Dektop456","Stopped","Stopped","2b-2c"
"Laptop123","NotFound","Running","3c-4c"
"Laptop456","NotFound","Running","4d-5d"
关于powershell - 将包含 PowerShell 对象表示法的文本文件转换为 CSV,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/72883926/
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 6年前关闭。 Improve this qu
我有实体: @Entity @Table(name = "CARDS") public class Card { @ManyToOne @JoinColumn(name = "PERSON_I
我正在尝试计算二维多边形的表面法线。我正在使用 OpenGL wiki 中的 Newell 方法来计算表面法线。 https://www.opengl.org/wiki/Calculating_a_S
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 7 年前。 Improve
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 9 年前。 Improve this
我这里有以下 XML: Visa, Mastercard, , , , 0, Discover, American Express siteonly, Buyer Pay
即将发生的 Google 政策变更迫使我们实现一个对话框,以通知欧盟用户有关 Cookie/设备标识符用于广告和分析的情况。我只想向欧盟用户显示此对话框。我不想使用额外的权限(例如 android.p
本文分享自华为云社区《华为大咖说 | 企业应用AI大模型的“道、法、术” ——道:认知篇》,作者:华为云PaaS服务小智。 本期核心观点 上车:AGI是未来5~10年内,每个人都无法回避的技
我有一个与酒精相关的网站,需要先验证年龄,然后才能让他们进入该网站。我使用 HttpModule 来执行此操作,该模块检查 cookie,如果未设置,我会将它们重定向到验证页面。我验证他们的年龄并存储
在欧盟,我们有一项法律,要求网页请求存储 cookie 的许可。我们大多数人都了解 cookie 并同意它们,但仍然被迫在任何地方明确接受它们。所以我计划编写这个附加组件(ff & chrome),它
以下在 C 和/或 C++ 中是否合法? void fn(); inline void fn() { /*Do something here*/ } 让我担心的是,第一个声明看起来暗示函数将被定义
我是一名优秀的程序员,十分优秀!