SharePoint 2010 PowerShell 系列 之 文檔管理 高級應用和企業案例(文檔遷移)


     PowerShell系列目錄

      前幾天寫了一篇初級應用,主要是為了讓大家對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的執行效率會讓你意想不到,最后祝大家:工作愉快

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM