我有一个包含S.M.A.R.T的日志文件。我的硬盘数据。 我想用PowerShell处理这个文件。 这是我的日志文件的一部分。
3 Spin_Up_Time 0x0020 100 100 000 Old_age Offline - 0
4 Start_Stop_Count 0x0030 100 100 000 Old_age Offline - 0
5 Reallocated_Sector_Ct 0x0032 100 100 000 Old_age Always - 0
这是我的代码
$i = 1
$a = Get-Content log.txt
do {
$trimmed = $a[$i].trim()
$splitted = $trimmed.split(" ")
$i++
}while ($i -le 3)
如果我使用.split(“”),它只能与thrid行一起使用。 如何正确拆分所有行?
谢谢
答案 0 :(得分:2)
更多的代码,但它为您提供了一些在最后更容易使用的东西:
$SMART = gc c:\temp\test.txt | %{
$temp = $_ -split " "|?{!([string]::IsNullOrWhiteSpace($_))}
new-object psobject -Property @{
"Entry"=$temp[0]
"TestName"=$temp[1]
"HexCode"=$temp[2]
"Number1"=$temp[3]
"Number2"=$temp[4]
"Number3"=$temp[5]
"Age"=$temp[6]
"Status"=$temp[7]
"Filler"=$temp[8]
"Zero?"=$temp[9]
}
}
$SMART|FT Entry,TestName,HexCode,Number1,Number2,Number3,Age,Status,Filler,Zero?
答案 1 :(得分:1)
这对你有什么作用?
$a = Get-Content log.txt
-split $a
我明白了
H:\> -split $a
3
Spin_Up_Time
0x0020
100
100
000
Old_age
Offline
-
0
4
Start_Stop_Count
0x0030
100
100
000
Old_age
Offline
-
0
5
Reallocated_Sector_Ct
0x0032
100
100
000
Old_age
Always
-
0
答案 2 :(得分:0)
我喜欢使用正则表达式'这是一个允许您为列命名的示例。
$a = Get-Content log.txt
$pattern = [regex]'(?<rowid>\d+)\s(?<desc>[a-zA-Z_]+)\s+(?<hexdata>0x\d{4})\s+(?<col4>\d{3})\s+(?<col5>\d{3})\s+(?<col6>\d{3})\s+(?<text1>.+?)\s+(?<state>.+?)-\s+0'
foreach ($line in $a) {
if ($line -match $pattern) {
$dataobj = New-Object PSObject
$dataobj | Add-Member -type NoteProperty -name "Description" -value $matches['desc']
$dataobj | Add-Member -type NoteProperty -name "Hex Data" -value $matches['hexdata']
$dataobj | Add-Member -type NoteProperty -name "State" -value $matches['state']
$dataobj
}
}
结果:
Description Hex Data State
----------- -------- -----
Spin_Up_Time 0x0020 Offline
Start_Stop_Count 0x0030 Offline
Reallocated_Sector_Ct 0x0032 Always