【发布时间】:2017-04-12 08:58:03
【问题描述】:
我使用以下网站来帮助我实现这一目标并进行故障排除。
- Download file from SharePoint
- How to download newest file from SharePoint using PowerShell
- Mike Smith's Tech Training Notes SharePoint, PowerShell and .Net!
- Upload file to a SharePoint doc library via PowerShell
- Download latest file from SharePoint Document Library
- How to iterate each folders in each of the SharePoint websites using PowerShell
- PowerShell's Get-ChildItem on SharePoint Library
我正在尝试从 SharePoint 文件夹下载随机文件,并且当我真正知道文件名和扩展名时,它就可以正常工作。
带有名称和扩展名的工作代码:
$SharePoint = "https://Share.MyCompany.com/MyCustomer/WorkLoad.docx"
$Path = "$ScriptPath\$($CustomerName)_WorkLoad.docx"
#Get User Information
$user = Read-Host "Enter your username"
$username = "$user@MyCompany"
$password = Read-Host "Enter your password" -AsSecureString
#Download Files
$WebClient = New-Object System.Net.WebClient
$WebClient.Credentials = New-Object System.Net.Networkcredential($UserName, $Password)
$WebClient.DownloadFile($SharePoint, $Path)
但是,我似乎无法弄清楚如何处理多个未知名称或扩展名的文件。
我已尝试映射驱动器,但结果是“驱动器映射失败”和“找不到网络路径”。错误:
$SharePoint = Read-Host 'Enter the full path to Delivery Site'
$LocalDrive = 'P:'
$Credentials = Get-Credential
if (!(Test-Path $LocalDrive -PathType Container)) {
$retrycount = 0; $completed = $false
while (-not $completed) {
Try {
if (!(Test-Path $LocalDrive -PathType Container)) {
(New-Object -ComObject WScript.Network).MapNetworkDrive($LocalDrive,$SharePoint,$false,$($Credentials.username),$($Credentials.GetNetworkCredential().password))
}
$Completed = $true
}
Catch {
if ($retrycount -ge '5') {
Write-Verbose "Mapping SharePoint drive failed the maximum number of times"
throw "SharePoint drive mapping failed for '$($SharePoint)': $($Global:Error[0].Exception.Message)"
} else {
Write-Verbose "Mapping SharePoint drive failed, retrying in 5 seconds."
Start-Sleep '5'
$retrycount++
}
}
}
}
我也使用了以下代码,结果相似或根本没有结果。
#Get User Information
$user = Read-Host "Enter your username"
$username = "$user@MyCompany"
$password = Read-Host "Enter your password" -AsSecureString
#Gathering the location of the Card Formats and Destination folder
$Customer = "$SharePoint\MyCustomer"
$Products = "$Path\$($CustomerName)\Products\"
#Get Documents from SharePoint
$credential = New-Object System.Management.Automation.PSCredential($UserName, $Password)
New-PSDrive -Credential $credential -Name "A" -PSProvider "FileSystem" -Root "$SharePoint"
net use $spPath #$password /USER:$user@corporate
#Get PMDeliverables file objects recursively
Get-ChildItem -Path "$Customer" | Where-Object { $_.name -like 'MS*' } | Copy-Item -Destination $Products -Force -Verbose
【问题讨论】:
标签: powershell variables sharepoint download copy