用powershell编写xml

时间:2011-11-15 09:36:30

标签: xml powershell sharepoint-2010 powershell-v2.0

我有一个脚本可以获取有关我的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并创建一个站点供管理员使用

我该怎么做?

感谢您的帮助!

2 个答案:

答案 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自定义后面的命令。