Using the Import-Csv Cmdlet
Read in a Comma-Separated Values File
The Import-Csv cmdlet provides a way for you to read in data from a comma-separated values file (CSV) and then display that data in tabular format within the Windows PowerShell console. For example, suppose you have a file named C:\Scripts\Test.txt, a file that contains the following data:Name,Department,Title Pilar Ackerman,Research,Manager Jonathan Haas,Finance,Finance Specialist Ken Myer,Finance,Accountant
Import-Csv c:\scripts\test.txt
Name Department Title ---- ---------- ----- Pilar Ackerman Research Manager Jonathan Haas Finance Finance Specialist Ken Myer Finance Accountant
Import-Csv c:\scripts\test.txt | Where-Object {$_.department -eq "Finance"}
Name Department Title ---- ---------- ----- Jonathan Haas Finance Finance Specialist Ken Myer Finance Accountant
Suppose we wanted to see the records for all employees except those from the Finance Department. In that case we’d use this command, with -ne meaning “not equal to”:
Import-Csv c:\scripts\test.txt | Where-Object {$_.department -ne "Finance"}
Name Department Title ---- ---------- ----- Pilar Ackerman Research Manager
Import-Csv c:\scripts\test.txt | Where-Object {$_.department -eq "Finance" -and $_.title -eq "Accountant"}
Name Department Title ---- ---------- ----- Ken Myer Finance Accountant
Import-Csv c:\scripts\test.txt | Where-Object {$_.department -eq "Research" -or $_.title -eq "Accountant"}
Name Department Title ---- ---------- ----- Pilar Ackerman Research Manager Ken Myer Finance Accountant
Import-Csv Aliases |
---|
|
Using the Import-Clixml Cmdlet
Reading in an XML File
Here’s a tough one for you. If the Export-Clixml cmdlet enables you to save data as an XML file, then what do you suppose the Import-Clixml cmdlet lets you do? OK, so maybe it wasn’t all that tough after all. At any rate, you’re right: Import-Clixml will import an XML file that was saved using Export-Clixml and then rebuilds the Windows PowerShell object for you. For example, suppose you use the Get-ChildItem cmdlet to retrieve a collection of files found in the folder C:\Scripts; you then use the Export-Clixml cmdlet to save that information as an XML file:Get-ChildItem c:\scripts | Export-Clixml c:\scripts\files.xml
$A = Import-Clixml c:\scripts\files.xml
data:image/s3,"s3://crabby-images/299bb/299bb8534cf57b33250178ee3f4f8b6bb0e59ab4" alt="Windows PowerShell"
The best part is that $A is not simply a collection of string data, but an actual Windows PowerShell object. How do we know that? Try piping $A through the Sort-Object cmdlet and see what happens:
$A | Sort-Object length
Using the Export-Csv Cmdlet
Saving Data as a Comma-Separated Values File
The Export-Csv cmdlet makes it easy to export data as a comma-separated values (CSV) file; all you need to do is call Export-Csv followed by the path to the CSV file. For example, this command uses Get-Process to grab information about all the processes running on the computer, then uses Export-Csv to write that data to a file named C:\Scripts\Test.txt:Get-Process | Export-Csv c:\scripts\test.txt
#TYPE System.Diagnostics.Process __NounName,Name,Handles,VM,WS,PM,NPM,Path,Company,CPU,FileVersion,ProductVersion,Description,Product,BasePriority, ExitCode,HasExited,ExitTime,Handle,HandleCount, Id,MachineName,MainWindowHandle,MainWindowTitle,MainModule, MaxWorkingSet,MinWorkingSet,Modules,NonpagedSystemMemorySize, NonpagedSystemMemorySize64, PagedMemorySize,PagedMemorySize64,PagedSystemMemorySize,PagedSystemMemorySize64,PeakPagedMemorySize, PeakPagedMemorySize64,PeakWorkingSet,PeakWorkingSet64, PeakVirtualMemorySize,PeakVirtualMemorySize64, PriorityBoostEnabled,PriorityClass,PrivateMemorySize,PrivateMemorySize64,PrivilegedProcessorTime,ProcessName, ProcessorAffinity, Responding,SessionId,StartInfo,StartTime,SynchronizingObject, Threads,TotalProcessorTime,UserProcessorTime,VirtualMemorySize,VirtualMemorySize64,EnableRaisingEvents, StandardInput,StandardOutput,StandardError,WorkingSet,WorkingSet64,Site,Container Process,alg,110,33714176,3698688,1273856,5400,C:\WINDOWS\System32\alg.exe,"Microsoft Corporation",0.046875, "5.1.2600.2180 (xpsp_sp2_rtm.040803-2158)",5.1.2600.2180,"Application Layer Gateway Service", "Microsoft? Windows? Operating System",8,,False,,2140,110,788,.,0,,"System.Diagnostics.ProcessModule (alg.exe)",1413120,204800,System.Diagnostics.ProcessModuleCollection,5400,5400,1273856,1273856,65756,65756, 1347584,1347584,3747840,3747840,35024896,35024896,True,Normal,1273856,1273856,00:00:00.0312500,alg,1,True,0, System.Diagnostics.ProcessStartInfo,"5/19/2006 7:37:03 AM",,System.Diagnostics.ProcessThreadCollection, 00:00:00.0468750,00:00:00.0156250,33714176,33714176,False,,,,3698688,3698688,,
Get-Process | Export-Csv c:\scripts\test.txt -encoding "unicode"
#TYPE System.Diagnostics.Process
Get-Process | Export-Csv c:\scripts\test.txt -notype
PS C:\Documents and Settings\gstemp> Get-Process | Export-Csv c:\scripts\test.txt Export-Csv : Access to the path 'C:\scripts\test.txt' is denied.
Get-Process | Export-Csv c:\scripts\test.txt -force
Export-Csv Aliases |
---|
|
Using the Export-Clixml Cmdlet
Saving Data as an XML File
Of course you can save Windows PowerShell output in XML format; what else would you use the Export-Clixml cmdlet for? This simple command uses the Get-Process cmdlet to retrieve information about all the processes running on the computer. That information is then piped to the Export-Clixml cmdlet, which in turn saves the data as an XML file named C:\Scripts\Test.xml:Get-Process | Export-Clixml c:\scripts\test.xml
data:image/s3,"s3://crabby-images/ffdfa/ffdfaa356eb8c3b7eee803dde166c53b38b588dc" alt="Windows PowerShell"
By default Export-Clixml overwrites any existing copy of C:\Scripts\Test.xml. If you’d prefer not to overwrite Test.xml then simply include the -noclobber parameter in your command:
Get-Process | Export-Clixml c:\scripts\test.xml -noclobber
Export-Clixml : File C:\scripts\test.xml already exists and NoClobber was specified.
Using the Out-File Cmdlet
Saving Data Directly to a Text File
The Out-File cmdlet enables you to send pipelined output directly to a text file rather than displaying that output on screen. For example, this command retrieves process information using Get-Process, then uses Out-File to write the data to the file C:\Scripts\Test.txt:Get-Process | Out-File c:\scripts\test.txt
data:image/s3,"s3://crabby-images/c720f/c720f5ebf0829560da420bb62584b1408918a732" alt="Windows PowerShell"
If you look closely, you’ll notice that the name of at least one process (PhotoshopElementsF …) could not be fully displayed onscreen. In turn, that’s exactly how this line will look in the saved text file:
61 5 1240 660 30 0.05 1084 PhotoshopElementsF...
Get-Process | Out-File c:\scripts\test.txt -width 120
61 5 1240 660 30 0.05 1084 PhotoshopElementsFileAgent
Using the Set-Content Cmdlet
Saving Data to a Text File
The primary use of Set-Content is to write data to a text file. For example, this command writes the text “This is a test” to the text file C:\Scripts\Test.txt:Set-Content c:\scripts\test.txt "This is a test"
Set-Content Aliases |
---|
|
No comments:
Post a Comment