Solved

Group unique filenames by expression?

Posted on 2010-11-10
2
813 Views
Last Modified: 2012-08-13
I have a directory full of unique names, all in the same format - Scriptname_datecodestuff.txt
How can I group these based on 'scriptname' ?
What I need to accomplish is I only want to have 10 'versions' of a file in this directory, so if their are more than 10, I need to delete the oldest of that group

Example files in the dir
localhost_11.02.2010-0645.txt
localhost_11.02.2010-0655.txt
localhost_11.02.2010-0705.txt
otherhost_11.02.2010-0645.txt
otherhost_11.02.2010-0650.txt
otherhost_11.02.2010-0650.txt

With those listtings, the 2 groups would be localhost with a count of 3, and otherhost with a count of 3.

I have something semi working, but its not elogant, and suffers some bad performance..
$Group =$File.Name.SubString(0,(($File.Name.Length)-20))
ElseIf (($Directory | Where {$_.Name -Match $Group} | %{$_.Name.SubString(0,(($_.Name.Length)-20))} | Group | %{$_.count}) -gt 10) {
		$Directory | Where {$_.Name -Match $Group} | Sort -Property LastWriteTime | Select -First 1 | Remove-Item

Open in new window

0
Comment
Question by:rwskas
2 Comments
 
LVL 6

Author Comment

by:rwskas
ID: 34103817
Sorry, that attached code was taken out of the entire script to just show the pieces that are relevant, the 2 lines dont flow together.
$file is a gci object
$directory = gci c:\temp
0
 
LVL 13

Accepted Solution

by:
soostibi earned 500 total points
ID: 34107118
Try this:

Get-ChildItem C:\temp | foreach-object {
    Add-Member -InputObject $_ -MemberType noteproperty -Name Groupname -Value $(if($_.name -match "^[^_]*"){$matches[0]}else{$null}) -PassThru} | ?{$_.groupname} |
        Group-Object -Property groupname | ?{$_.count -gt 10} | foreach-object {
            $_.group | Sort-Object -Property lastwritetime | Select-Object -First 1 | Remove-Item
        }

Open in new window

0

Featured Post

Problems using Powershell and Active Directory?

Managing Active Directory does not always have to be complicated.  If you are spending more time trying instead of doing, then it's time to look at something else. For nearly 20 years, AD admins around the world have used one tool for day-to-day AD management: Hyena. Discover why

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

How to sign a powershell script so you can prevent tampering, and only allow users to run authorised Powershell scripts
Set OWA language and time zone in Exchange for individuals, all users or per database.

856 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question