2021-04-07 11:53:57 +02:00
|
|
|
#!/usr/bin/pwsh
|
2021-02-04 20:44:13 +01:00
|
|
|
<#
|
2021-04-07 15:17:49 +02:00
|
|
|
.SYNTAX smart-data2csv.ps1 [<directory>]
|
2021-03-22 20:10:18 +01:00
|
|
|
.DESCRIPTION converts the S.M.A.R.T. JSON files in the current/given directory to a CSV table for analysis
|
|
|
|
(use query-smart-data.ps1 to generate those JSON files)
|
|
|
|
.LINK https://github.com/fleschutz/PowerShell
|
|
|
|
.NOTES Author: Markus Fleschutz / License: CC0
|
2021-02-04 20:44:13 +01:00
|
|
|
#>
|
|
|
|
|
2021-02-18 20:17:55 +01:00
|
|
|
param($Directory = "")
|
2021-02-04 20:44:13 +01:00
|
|
|
|
|
|
|
function WriteCsvHeader { param([PSCustomObject]$File)
|
2021-02-06 18:04:42 +01:00
|
|
|
foreach($Entry in $File.ata_smart_attributes.table) {
|
|
|
|
[int]$ID = $Entry.id
|
|
|
|
$Name = $Entry.name
|
|
|
|
write-host -nonewline "$Name ($ID);"
|
2021-02-04 20:44:13 +01:00
|
|
|
}
|
|
|
|
write-host ""
|
|
|
|
}
|
|
|
|
|
2021-02-06 18:04:42 +01:00
|
|
|
function WriteCsvDataRow { param([PSCustomObject]$File)
|
|
|
|
foreach($Entry in $File.ata_smart_attributes.table) {
|
|
|
|
[int]$ID = $Entry.id
|
|
|
|
switch ($ID) {
|
|
|
|
1 { write-host -nonewline "$($Entry.raw.value);" }
|
|
|
|
4 { write-host -nonewline "$($Entry.raw.value);" }
|
|
|
|
7 { write-host -nonewline "$($Entry.raw.value);" }
|
|
|
|
9 { write-host -nonewline "$($Entry.raw.value);" }
|
|
|
|
12 { write-host -nonewline "$($Entry.raw.value);" }
|
|
|
|
190 { write-host -nonewline "$($Entry.raw.string);" }
|
|
|
|
191 { write-host -nonewline "$($Entry.raw.value);" }
|
|
|
|
192 { write-host -nonewline "$($Entry.raw.value);" }
|
|
|
|
193 { write-host -nonewline "$($Entry.raw.value);" }
|
|
|
|
195 { write-host -nonewline "$($Entry.raw.value);" }
|
|
|
|
240 { write-host -nonewline "$($Entry.raw.string);" }
|
|
|
|
241 { write-host -nonewline "$($Entry.raw.value);" }
|
|
|
|
242 { write-host -nonewline "$($Entry.raw.value);" }
|
|
|
|
default { write-host -nonewline "$($Entry.value);" }
|
|
|
|
}
|
2021-02-04 20:44:13 +01:00
|
|
|
}
|
|
|
|
write-host ""
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
2021-02-07 15:01:08 +01:00
|
|
|
if ($Directory -eq "" ) {
|
|
|
|
$Directory = "$PWD"
|
2021-02-04 20:44:13 +01:00
|
|
|
}
|
|
|
|
|
2021-02-07 15:01:08 +01:00
|
|
|
$Filenames = get-childitem -path "$Directory/SMART*.json"
|
2021-02-04 20:44:13 +01:00
|
|
|
$ModelFamily = $ModelName = $SerialNumber = ""
|
|
|
|
|
2021-02-06 18:04:42 +01:00
|
|
|
[int]$Row = 1
|
2021-02-04 20:44:13 +01:00
|
|
|
foreach($Filename in $Filenames) {
|
|
|
|
$File = get-content $Filename | ConvertFrom-Json
|
|
|
|
|
|
|
|
if ($File.model_family -ne $ModelFamily) {
|
|
|
|
if ($ModelFamily -eq "") {
|
|
|
|
$ModelFamily = $File.model_family
|
|
|
|
} else {
|
|
|
|
write-error "Different model families: $ModelFamily vs. $($File.model_family)"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($File.model_name -ne $ModelName) {
|
|
|
|
if ($ModelName -eq "") {
|
|
|
|
$ModelName = $File.model_name
|
|
|
|
} else {
|
|
|
|
write-error "Different model names: $ModelName vs. $($File.model_name)"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($File.serial_number -ne $SerialNumber) {
|
|
|
|
if ($SerialNumber -eq "") {
|
|
|
|
$SerialNumber = $File.serial_number
|
|
|
|
} else {
|
|
|
|
write-error "Different serial numbbers: $SerialNumber vs. $($File.serial_number)"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-02-06 18:04:42 +01:00
|
|
|
if ($Row -eq 1) {
|
|
|
|
WriteCsvHeader $File
|
|
|
|
}
|
|
|
|
WriteCsvDataRow $File
|
|
|
|
$Row++
|
2021-02-04 20:44:13 +01:00
|
|
|
}
|
|
|
|
exit 0
|
|
|
|
} catch {
|
2021-02-16 10:03:20 +01:00
|
|
|
write-error "ERROR: line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])"
|
2021-02-04 20:44:13 +01:00
|
|
|
exit 1
|
|
|
|
}
|