设为首页 收藏本站
查看: 1282|回复: 0

SharePoint 2010 PowerShell 系列 之 文档管理 高级应用和企业案例(文档迁移)

[复制链接]

尚未签到

发表于 2015-9-25 11:31:23 | 显示全部楼层 |阅读模式
  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  
}
}
}
}
  第四:全部代码


DSC0000.gif DSC0001.gif 全部代码


# 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的执行效率会让你意想不到,最后祝大家:工作愉快
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-118631-1-1.html 上篇帖子: SharePoint 2010 PowerShell 系列 之 Create List and Field 下篇帖子: SharePoint 2010 最佳实践学习总结------第2章 SharePoint Windows PowerShell指南
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表