First published on MSDN on Oct 04, 2012
A customer recently needed some help deleting a bunch of sites of old sites in an environment that was no longer in use. They used STSADM enumsites to take an inventory of what was in the farm/web application. They used the greater than(>) symbol in the command line to send the output to a file. Enumsites happens to dump out XML. Once they did that, they had someone review the sites, and remove the sites that were still needed, creating a list/file of sites to delete. They needed a way to call STSADM deletesites, using an input file. This can be done with PowerShell. Here's an example.
[xml]$SitesToDelete = Get-Content C:\folder\SitesToDelete.xml
$SitesToDelete.Sites.Site | % { & "$env:ProgramFiles\common files\microsoft shared\web server extensions\12\bin\stsadm.exe" -o deletesite -url $($_.url) -gradualdelete }
We can see here that we set a variable $SitesToDelete as the content of our XML file. Then we read the XML, for each site entry by appending on Sites.Site. From there, we call the STSADM command, adding in the URL of the site to delete using $_.url, which reads the URL value from the site entry in our XML.
You can use this type of syntax/logic to call a number of different STSADM commands with PowerShell. Make sure you adjust the path properly for SharePoint 2007(12), SharePoint 2010(14) and SharePoint 2013(15).
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.