我有一个脚本可以获取有关我的SharePoint场所需的所有信息:
[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint") > $null
$farm = [Microsoft.SharePoint.Administration.SPFarm]::Local
$websvcs = $farm.Services | where -FilterScript {$_.GetType() -eq [Microsoft.SharePoint.Administration.SPWebService]}
$webapps = @()
foreach ($websvc in $websvcs) {
write-output "Web Applications"
write-output ""
foreach ($webapp in $websvc.WebApplications) {
write-output "Webapp Name -->"$webapp.Name
write-output ""
write-output "Site Collections"
write-output ""
foreach ($site in $webapp.Sites) {
write-output "Site URL --> -->" $site.URL
write-output ""
write-output "Websites"
write-output ""
foreach ($web in $site.AllWebs) {
write-output "Web URL --> --> -->" $web.URL
write-output ""
write-output "Lists"
write-output ""
foreach ($list in $web.Lists) {
write-output "List Title --> --> --> -->" $list.Title
write-output ""
}
foreach ($group in $web.Groups) {
write-output "Group Name --> --> --> -->" $group.Name
write-output ""
foreach ($user in $group.Users) {
write-output "User Name --> --> --> -->" $user.Name
write-output ""
}
}
}
}
}
}
我想将输出转换为XML文件,然后将xml文件连接到HTML并创建一个站点供管理员使用
我该怎么做?
感谢您的帮助!
答案 0 :(得分:3)
我想说你有2个选项应该相当简单:
最简单的方法是,而不是使用write-output,将字符串构建为xml。
$procs = get-Process
$xml = "<xml>"
foreach($proc in $procs)
{
$xml += "<process name='" + $proc.Name + "' id='Proc_"+$proc.Id+"'>"
$xml += "<modules>"
foreach($module in $proc.Modules)
{
$xml += "<module>"
$xml += $module.ModuleName
$xml += "</module>"
}
$xml += "</modules>"
$xml += "</process>"
}
$xml += "</xml>"
$xml | out-File -FilePath c:\temp\proc1.xml
或者 - 您可以将输出构建为psobject,然后尝试使用其中一个PowerShell cmdlet将其输出为XML。可能是更健壮的方法,因为您可以通过管道使用其他PowerShell cmdlet。这看起来像这样:
$procs = get-Process
$processObject = @()
foreach($proc in $procs)
{
$procInfo = new-Object PSObject
$procInfo | add-Member NoteProperty -Name "Process" $proc.Name
$procInfo | add-Member NoteProperty -Name "ID" $proc.Id
$moduleInfo = @()
foreach($module in $proc.Modules)
{
$moduleInfo += $module.ModuleName
}
$procInfo | add-Member NoteProperty -Name "Module" $moduleInfo
$processObject += $procInfo
}
$processObject | export-Clixml c:\temp\procs.xml
答案 1 :(得分:2)
如果要将对象输出到XML,可以尝试使用Export-Clixml命令。例如:
dir | Export-Clixml c:\ temp \ output.xml
如果您想直接使用HTML页面,可以使用commande ConvertTo-Html:
dir | ConvertTo-Html&gt; C:\ TEMP \ output.html
您可以使用head,title,body和CSS自定义后面的命令。