프로세스의 PercentProcessorTime을 가져 오는 스크립트 powershell이 있습니다. 아래와 같이 결과의powershell에서 파이프 출력을 한 줄로 배열하는 방법
$Processes = (get-wmiobject Win32_PerfFormattedData_PerfProc_Process)
$Processes | %{ New-Object psobject -Property `
@{ Time = $_.PercentProcessorTime;
Name = ($_.name -replace "#\d+", "")}}`
| ?{ $_.Name -notmatch "_Total|Idle" } `
| Group-Object Name `
| %{ New-Object psobject -Property `
@{ Name = $_.Name;
Sum = ($_.Group | Measure-Object Time -Sum).Sum }} `
| Format-Table
형식 :
하지만 데이터베이스에 삽입 할 다음과 같이 결과를 포맷 할 :
OK |Idle=100 System=6 smss=0 csrss=0 wininit=0 services=0 lsass=0 lsm=0 svchost=18 ICTrigger=0 nvvsvc=0 ICDCMGR64=0 svchost#2=0 winlogon=0 svchost#3=0 svchost#4=0 svchost#5=0 igfxCUIService=0 svchost#6=0 spoolsv=0 svchost#7=0 armsvc=0 ShieldStart=0 svchost#8=0 GateMan=0 HeciServer=0 Jhi_service=0 NHCAAgent=0 nvxdsync=0 nvvsvc#1=0 nscp=0 PaSvc=0 pcdrmsvc=0 NSCHIM=0 ASDSvc=0 secugate64=0 WindowsSecuService=0 WinFil32=0 WmiPrvSE=0 svchost#9=0 papersrv64=0 WUDFHost=0 svchost#10=0 svchost#11=0 WmiP rvSE#1=0 PaTray=0 unsecapp=0 WmiPrvSE#2=0 LMS=0 SWMAgent=0
는 내가 그것을 해결하기 위해 도와주세요. 정말 감사합니다 ^^
'Format- *'cmdlets는 데이터를 생성하는 것이 아니라 _display 형식화를위한 것입니다. 원하는 결과물을 질문에 직접 포함 시키십시오. 설명과 함께 텍스트로 입력하십시오. 또한 [좋은 질문을하는 방법] (http://stackoverflow.com/help/how-to-ask)을 읽어보십시오. – mklement0
이것은 convertto-stringdata를 사용하는 전형적인 예입니다. 기본값으로는 PS가 제공되지 않습니다. Convertfrom-stringdata는 Hashtable 형식으로 데이터를 분할하고 역순으로 key = value 쌍으로 만듭니다. [이 링크] (https://blogs.technet.microsoft.com/heyscriptingguy/2011/01/17/simplify-powershell-hash-table-creation-with-a-simple-cmdlet/)를 사용하면 . –