Summary: Microsoft Scripting Guy, Ed Wilson, talks about using Windows PowerShell to find files that have not been accessed for some time.
Hey, Scripting Guy! On our server, we have tons of files. Unfortunately, many of them haven’t been accessed for years. I know the cost of storage is coming down, but the management overhead and cost of building new datacenters does not come down. In fact, it is going up. So we need a way to identify files that have not been accessed in a long time. If we could delete them, it would be even better.
—AB
Hello AB,
Microsoft Scripting Guy, Ed Wilson, is here. Tonight is the speaker’s dinner for Windows PowerShell Saturday event in Charlotte, North Carolina. We have around 50 people coming to the Scripting House. We also have a couple of people who will be spending the night. Expect to see some new videos coming out as Honorary Scripting Guy and Windows PowerShell MVP, Sean Kearney, and I get together and spend the night playing around with cameras and video equipment.
If you have not yet registered, I think there are a couple of tickets left, so don’t delay or they will be gone. The list of speakers reads like a who’s who in the Windows PowerShell world. In fact, six of the speakers at our event in Charlotte are also going to be speaking at the Windows PowerShell Summit in Seattle in April. To register, go to PowerShell Saturday #007.
Note This is the fifth in a series of posts that talk about working with files and folders by using Windows PowerShell.
You should read the previous posts:
- List Files in Folders and Subfolders with PowerShell
- Use PowerShell to Create CSV File to Open in Excel
- List Music File Metadata in a CSV and Open in Excel with PowerShell
- Use PowerShell to Find Metadata from Photograph Files
There are three basic properties of a file that I commonly use when looking at files that are neglected. The first is the date it was created, the second is when it was modified, and last is when it was accessed. These properties are visible when I to go the General tab of a file in File Explorer. An example of these values is shown here:
I can use the Get-ChildItem cmdlet and the Select-Object cmdlet and return the three properties. The command to do this is:
Get-ChildItem c:\fso -File | select name, *time
The following image illustrates the command and its output:
It is possible that a file may have been accessed, but the access did not modify the file. It is also possible that a file may have been created, and then neither accessed or written to again. For my purpose today, I am going to use the LastWriteTime property. I want to create a simple function that I can use that permits me to supply an array of folders and a begin date. The function is shown here:
Function Get-NeglectedFiles
{
Param([string[]]$path,
[int]$numberDays)
$cutOffDate = (Get-Date).AddDays(-$numberDays)
Get-ChildItem -Path $path |
Where-Object {$_.LastAccessTime -le $cutOffDate}
}
I write the function in the Windows PowerShell ISE, and I run it to load the Get-NeglectedFiles function. Now, I go to the interactive pane at the bottom of the Windows PowerShell ISE, and I call the function a couple of times. In the first command line, I look for files that have not been accessed in 60 days:
Get-NeglectedFiles -path c:\fso -numberDays 60 | select name, lastaccesstime
Next, I look for files that have not been accessed in 90 days:
Get-NeglectedFiles -path c:\fso -numberDays 90 | select name, lastaccesstime
The following image illustrates this process:
The reason for doing this is so I can gain confidence that the function works as I think it should. It appears to do so. Now, I am going to look for files that have not been accessed in 180 days, as shown here:
Cool, I found a few files. Now, I know that I have backups of these files, so I am going to delete them. To do this, I change the Select command to Remove-Item:
Get-NeglectedFiles -path c:\fso -numberDays 180 | Remove-Item -Force
When I check for the files, nothing reports back. This is shown in the following image:
AB, that is all there is to using Windows PowerShell to find files that have not been accessed in an extended period of time. This also concludes File Week. Join me tomorrow when I will talk about more really cool Windows PowerShell stuff.
I invite you to follow me on Twitter and Facebook. If you have any questions, send email to me at scripter@microsoft.com, or post your questions on the Official Scripting Guys Forum. See you tomorrow. Until then, peace.
Ed Wilson, Microsoft Scripting Guy
How would I run this recursively?
Add a -Recurse flag to the Get-ChildItem command.
I noticed that when running the script again the LastAccessTime has been updated to the time the script was first run. When using Get-ChildItem how can you stop the LastAccessTime from being updated?