前幾天寫了一篇初級應用,主要是為了讓大家對PowerShell管理文檔庫有初步認識,經過上一篇文章,相信大家已經了解了PowerShell管理文檔庫,這一篇主要講高級應用及企業應用的經典案例。
高級用法:
一、創建文件夾與子文件夾
先寫一個創建文件夾的公用方法 $url 代表文件夾的路徑(即:DocLib/XX/) $list 代表對應的列表, $name 文件夾的名字 return 的是一個文件夾對象,在下面的操作過程中會用到。
# Add Item Function AddItemFolder($url,$list,$name){ Write-host ".............Starting create " $name " Folder,please waiting............." -foregroundcolor blue $folder = $list.AddItem($url,$Folder,$name) $folder.Update() return $folder Write-host ".............. " $name " Folder already is created......................." -foregroundcolor blue }
獲取文檔庫並添加文件夾與子文件夾
$listName = "組織過程管理文檔庫" $listDescription = "組織過程管理文檔庫" DeleteList $web $listName #delete AddList $web $listName $listDescription $DocTemp #add $list = $web.Lists.TryGetList($listName) $f = AddItemFolder "" $list "PowerShellFolder0" #創建文件夾 write-host $f.Url -foregroundcolor red AddItemFolder $f.Url $list "PowerShellFolder0_1" #創建子文件夾
二、上傳本地文件及批量上傳
$folderFile = $web.GetFolder("組織過程管理文檔庫").Files #獲取文檔庫 $file = Get-ChildItem C:/123.docx $folderFile.Add($f.Url+"/123.docx",$file.OpenRead(),$true) #$f.Url 等兄弟們學習的時候調試一下就明白為什么要這樣寫了 $folderFile.Add($f.Url.split('/')[0]+"/123.docx",$file.OpenRead(),$true) #上傳到根目錄。 #批量上傳 Get-ChildItem C:/ -filter "*.docx" | ForEach-Object{ $folderFile.Add($f.Url.split('/')[0]+"/$($_.Name)",$_.OpenRead(),$true) }
三、復制文件,從一個文檔庫移動到另一個文檔庫
$list = $web.Lists.TryGetList("組織過程管理文檔庫") write-host $list.RootFolder $Doc1 = $web.GetFolder($list.RootFolder) #獲取文檔庫 Write-Host "Count:" $Doc1.Files.Count #Copy foreach($file in $Doc1.Files){ $file.CopyTo("DocLib1/"+$file.Name,$true) }
四、移動文件,從一個文檔庫移動到另一個文檔庫,在這什么不能用 Feach,兄弟們可以想想,很有學問的,在項目開發過程中經常遇到這樣的問題,呵呵........
$list = $web.Lists.TryGetList("組織過程管理文檔庫") write-host $list.RootFolder $Doc1 = $web.GetFolder($list.RootFolder) #獲取文檔庫 Write-Host "Count:" $Doc1.Files.Count #Move $count = $Doc1.Files.Count While($count -ne 0){ Write-host $count $Doc1.Files[$count - 1].MoveTo("DocLib2/"+$Doc1.Files[$count - 1].Name,$true) $count -- }
應用案例
SharePoint網站經過一年后,客戶說默認樣式太難看了,還要添加新的需求,結果就要重新做頁面與提取新的需求,目前項目正在進行中,但一直有一個問題沒底不知如何解決,就是當我們把項目做完了,目前正在用的平台上面有很多文檔,文檔應該如何移動呢,一直想不出好的辦法,對SharePoint數據遷移也沒有研究,只是對PowerShell有了解,最終決定先研究SharePoint,想用命令進行數據遷移,為什么不研究其它是因為自己對Powershell了解的比較多................說了這么多廢話,其實就是 文檔遷移
遷移思路: 遍歷文檔庫里的文件夾(用遞歸),之后在另一個文檔庫里創建遞歸出來的文件夾,同時再拷貝文件
具體方法有如下幾個:
第一、遞歸文件夾 目前有問題,不知為什么,但有替代方案,用Fearch多次循環
Function RecursiveFolder($folder,$doc,$obj){ foreach($folderSub in $folder.SubFolders){ Write-host $folderSub.Name # AddItemFolder 這個函數調用總是出問題,"找不到對應的重載方法" 真是無語了,只要把這個函數放到遞歸方法 #里就出問題,真的想不出什么原因,會的兄弟給點指示 $folderObjSub = AddItemFolder $obj.Url $doc $folderSub.Name #創建文件夾 RecursiveFolder $folderSub $doc $folderObjSub } }
多次循環就不會出錯
foreach($f in $folderList.SubFolders){ if($f.Name -ne "Forms" ){ if($f.Name -ne "Document" ){ #Write-host $f.Name $f.SubFolders.Add($f.Name) $folderObj = AddItemFolder "" $listForm $f.Name #創建文件夾 write-host $folderObj.Url GetFiles $f $folderObj.Url+"/" #復制文件 #RecursiveFolder $f $listForm $folderObj foreach($folderSub in $f.SubFolders){ Write-host $folderSub.Name $folderObjSub = AddItemFolder $folderObj.Url $listForm $folderSub.Name #創建文件夾 #RecursiveFolder $folderSub $doc $folderObjSub GetFiles $folderSub $folderObjSub.Url+"/" #復制文件 } } }
第二、遍歷文件
Function GetFiles($folder,$url){ foreach($file in $folder.Files){ write-host $file.Name $file.CopyTo($url+$file.Name,$true) } }
第三、詳細代碼
Function EachFolder($web){ $list = $web.Lists.TryGetList("組織過程管理文檔庫") $folderList = $web.GetFolder($list.RootFolder) #獲取文檔庫 $listForm = $web.Lists.TryGetList("項目流程表單模板庫") $folderListForm = $web.GetFolder($listForm.RootFolder) #獲取文檔庫 foreach($f in $folderList.SubFolders){ if($f.Name -ne "Forms" ){ if($f.Name -ne "Document" ){ #Write-host $f.Name $f.SubFolders.Add($f.Name) $folderObj = AddItemFolder "" $listForm $f.Name #創建文件夾 write-host $folderObj.Url GetFiles $f $folderObj.Url+"/" RecursiveFolder $f $listForm $folderObj } } } }
第四:全部代碼

# Check to ensure Microsoft.SharePoint.PowerShell is loaded $Snapin = get-PSSnapin | Where-Object {$_.Name -eq 'Microsoft.SharePoint.Powershell'} if($Snapin -eq $null){ Write-host "Loading SharePoint Powershell Snapin" Add-PSSnapin "Microsoft.SharePoint.Powershell" } #SPListTemplateType $DocTemp = [Microsoft.SharePoint.SPListTemplateType]::DocumentLibrary $GenericListTemp = [Microsoft.SharePoint.SPListTemplateType]::GenericList $Folder = [Microsoft.SharePoint.SPFileSystemObjectType]::Folder #SPFieldType $TextFieldType = [Microsoft.SharePoint.SPFieldType]::Text $NoteFieldType = [Microsoft.SharePoint.SPFieldType]::Note $ChoiceFieldType = [Microsoft.SharePoint.SPFieldType]::Choice $NumberFieldType = [Microsoft.SharePoint.SPFieldType]::Number #SPAddFieldOptions $DefaultViewFieldOptions = [Microsoft.SharePoint.SPAddFieldOptions]::AddFieldToDefaultView # Get WebApplication $WebAppName = "SharePoint - 999" $WebApp = Get-SPWebApplication $WebAppName $WebUrl = $WebApp.Url+"ProcessAsset" write-host $WebUrl $Web = Get-SPWeb $WebUrl Function AddList($web,$listName,$listDescription,$listTemplate){ Write-host ".............Starting create " $listName ",please waiting............." -foregroundcolor yellow $web.Lists.Add($listName,$listDescription,$listTemplate) Write-host ".............. " $listName " already is created......................." -foregroundcolor green } # List OnQuickLaunch Function OnQuickLaunchList($list,$bool){ $list.OnQuickLaunch = $bool $list.Update() } # Add Item Function AddItemFolder($url,$list,$name){ Write-host ".............Starting create " $name " Folder,please waiting............." -foregroundcolor blue $folder = $list.AddItem($url,$Folder,$name) $folder.Update() return $folder Write-host ".............. " $name " Folder already is created......................." -foregroundcolor blue } # Delete List Function DeleteList($web,$listName){ $list = $web.Lists.TryGetList($listName) if($list -ne $null){ Write-Host "............." $listName "already exists,deleting................" -foregroundcolor red $list.Delete() Write-host "............." $listName "already is deleted....................." -foregroundcolor Green Write-host "" } } #Add Fields Function AddFieldXml($list,$xml,$bool,$fieldOptions){ $list.Fields.AddFieldAsXml($xml,$bool,$fieldOptions) } Function AddDoc_OrganizationProcessManager($web){ $listName = "組織過程管理文檔庫" $listDescription = "組織過程管理文檔庫" DeleteList $web $listName #delete AddList $web $listName $listDescription $DocTemp #add $list = $web.Lists.TryGetList($listName) $f = AddItemFolder "" $list "PowerShellFolder0" #創建文件夾 write-host $f.Url -foregroundcolor red AddItemFolder $f.Url $list "PowerShellFolder0_1" #創建子文件夾 $folderFile = $web.GetFolder("組織過程管理文檔庫").Files #獲取文檔庫 $file = Get-ChildItem C:/123.docx $folderFile.Add($f.Url+"/123.docx",$file.OpenRead(),$true) #$f.Url 等兄弟們學習的時候調試一下就明白為什么要這樣寫了 $folderFile.Add($f.Url.split('/')[0]+"/123.docx",$file.OpenRead(),$true) #上傳到根目錄。 #批量上傳 Get-ChildItem C:/ -filter "*.docx" | ForEach-Object{ $folderFile.Add($f.Url.split('/')[0]+"/$($_.Name)",$_.OpenRead(),$true) } #$AddSubFolder = $web.GetFolder("組織過程管理文檔庫") #$AddSubFolder.SubFolders.Add("Archive") #AddItemFolder "" $list "PowerShellFolder1" #AddItemFolder "" $list "PowerShellFolder2" OnQuickLaunchList $list True } #$PSSnapin = Add-PsSnapin Microsoft.SharePoint.PowerShell -ErrorAction SilentlyContinue | Out-Null #clear #$org = "http://blueleader" #$dest = "http://redleader" #$orgLibrary = (Get-SPWeb $org).Folders["Documents"] #$destLibrary = (Get-SPWeb $dest).Folders["Documents"] #$destFiles = $destLibrary.Files #foreach ($file in $orgLibrary.Files) #{ #$curFile = $file.OpenBinary() #$destURL = $destFiles.Folder.Url + "/" + $file.Name #$destFiles.Add($destURL, $curFile, $true) #} Function CopyToDoc($web){ $list = $web.Lists.TryGetList("組織過程管理文檔庫") write-host $list.RootFolder $Doc1 = $web.GetFolder($list.RootFolder) #獲取文檔庫 Write-Host "Count:" $Doc1.Files.Count #Copy foreach($file in $Doc1.Files){ $file.CopyTo("DocLib1/"+$file.Name,$true) } #Move $count = $Doc1.Files.Count While($count -ne 0){ Write-host $count $Doc1.Files[$count - 1].MoveTo("DocLib2/"+$Doc1.Files[$count - 1].Name,$true) $count -- } } Function EachFolder($web){ $list = $web.Lists.TryGetList("組織過程管理文檔庫") $folderList = $web.GetFolder($list.RootFolder) #獲取文檔庫 $listForm = $web.Lists.TryGetList("項目流程表單模板庫") $folderListForm = $web.GetFolder($listForm.RootFolder) #獲取文檔庫 foreach($f in $folderList.SubFolders){ if($f.Name -ne "Forms" ){ if($f.Name -ne "Document" ){ #Write-host $f.Name $f.SubFolders.Add($f.Name) $folderObj = AddItemFolder "" $listForm $f.Name #創建文件夾 write-host $folderObj.Url GetFiles $f $folderObj.Url+"/" RecursiveFolder $f $listForm $folderObj } } } } Function RecursiveFolder($folder,$doc,$obj){ foreach($folderSub in $folder.SubFolders){ Write-host $folderSub.Name # AddItemFolder 這個函數調用總是出問題,"找不到對應的重載方法" 真是無語了,只要把這個函數放到遞歸方法 #里就出問題,真的想不出什么原因,會的兄弟給點指示 $folderObjSub = AddItemFolder $obj.Url $doc $folderSub.Name #創建文件夾 RecursiveFolder $folderSub $doc $folderObjSub } } Function GetFiles($folder,$url){ foreach($file in $folder.Files){ write-host $file.Name $file.CopyTo($url+$file.Name,$true) } } if($Web -ne $null){ #AddDoc_OrganizationProcessManager $Web #CopyToDoc $Web #DeleteList $web "文檔" #默認的文檔庫刪除 EachFolder $Web $Web.Dispose() } else{ Write-Host $WebUrl " is not existing" }
經過這幾天的學習與總結,問題總算解決了,並且發現PowerShell管理也是不錯的選擇,速度是相當給力的,想體驗的兄弟就快來試試吧,PowerShell的執行效率會讓你意想不到,最后祝大家:工作愉快