使用Powershell将文件添加到Sharepoint子列表

时间:2019-07-01 08:04:18

标签: powershell sharepoint

我使用Powershell将文件从本地驱动器上传到共享点站点

我有一个列表“ Documents”,他包含一个名为“ X”的文件夹

我的问题是:如何将文件上传到X文件夹

这是我的代码:

$SiteURL = "domain/sites/testing/"
$libraryName="Documents/X"
$SPOnlineUserName="user@domain"

当我上传到文档($libraryName变量为“ Documents”)时,脚本运行良好

但是在$libraryName="Documents/X"文件夹中,出现此错误:

List 'Documents/X' does not exist at site with URL 'domain/sites/testing'

有解决此问题的想法吗?

[编辑]

我可以通过浏览器访问“ X”文件夹。

最好。

1 个答案:

答案 0 :(得分:1)

针对大文件上传进行更新:

Add-Type -Path "C:\Program Files\Common Files\Microsoft Shared\Web Server Extensions\16\ISAPI\Microsoft.SharePoint.Client.dll"
Add-Type -Path "C:\Program Files\Common Files\Microsoft Shared\Web Server Extensions\16\ISAPI\Microsoft.SharePoint.Client.Runtime.dll"

$SiteURL="https://tenant.sharepoint.com/sites/dev"
$User = "user@tenant.onmicrosoft.com"  
$Password = '*********************' 
$Credentials = New-Object Microsoft.SharePoint.Client.SharePointOnlineCredentials($User,(ConvertTo-SecureString $Password -AsPlainText -Force))
$ctx = New-Object Microsoft.SharePoint.Client.ClientContext($SiteURL)
$ctx.Credentials = $Credentials

$fileChunkSizeInMB = 9

# Each sliced upload requires a unique ID.
$UploadId = [GUID]::NewGuid()

# Get the name of the file.
$UniqueFileName = [System.IO.Path]::GetFileName("D:\\Yoyo.wmv")


# Get the folder to upload into. 
$Docs = $ctx.Web.Lists.GetByTitle("Documents")
$ctx.Load($Docs)
$ctx.Load($Docs.RootFolder)
$ctx.ExecuteQuery()

# Get the information about the folder that will hold the file.
$ServerRelativeUrlOfRootFolder = $Docs.RootFolder.ServerRelativeUrl

# File object.
[Microsoft.SharePoint.Client.File] $upload


# Calculate block size in bytes.
$BlockSize = $fileChunkSizeInMB * 1024 * 1024


# Get the size of the file.
$FileSize = (Get-Item $fileName).length

if ($FileSize -le $BlockSize)
{
    # Use regular approach.
    $FileStream = New-Object IO.FileStream($fileName,[System.IO.FileMode]::Open)
    $FileCreationInfo = New-Object Microsoft.SharePoint.Client.FileCreationInformation
    $FileCreationInfo.Overwrite = $true
    $FileCreationInfo.ContentStream = $FileStream
    $FileCreationInfo.URL = $UniqueFileName
    $Upload = $Docs.RootFolder.Files.Add($FileCreationInfo)
    $ctx.Load($Upload)
    $ctx.ExecuteQuery()
    return $Upload
}
else
{

    # Use large file upload approach.
    $BytesUploaded = $null

    $Fs = $null

    Try {

        $Fs = [System.IO.File]::Open($fileName, [System.IO.FileMode]::Open, [System.IO.FileAccess]::Read, [System.IO.FileShare]::ReadWrite)

        $br = New-Object System.IO.BinaryReader($Fs)

        $buffer = New-Object System.Byte[]($BlockSize)
        $lastBuffer = $null
        $fileoffset = 0
        $totalBytesRead = 0
        $bytesRead
        $first = $true
        $last = $false

        # Read data from file system in blocks. 
        while(($bytesRead = $br.Read($buffer, 0, $buffer.Length)) -gt 0) {

            $totalBytesRead = $totalBytesRead + $bytesRead

            # You've reached the end of the file.
            if($totalBytesRead -eq $FileSize) {
                $last = $true
                # Copy to a new buffer that has the correct size.
                $lastBuffer = New-Object System.Byte[]($bytesRead)
                [array]::Copy($buffer, 0, $lastBuffer, 0, $bytesRead)
            }

            If($first)
            {
                $ContentStream = New-Object System.IO.MemoryStream

                # Add an empty file.
                $fileInfo = New-Object Microsoft.SharePoint.Client.FileCreationInformation
                $fileInfo.ContentStream = $ContentStream
                $fileInfo.Url = $UniqueFileName
                $fileInfo.Overwrite = $true
                $Upload = $Docs.RootFolder.Files.Add($fileInfo)
                $ctx.Load($Upload)

                # Start upload by uploading the first slice.

                $s = [System.IO.MemoryStream]::new($buffer) 

                # Call the start upload method on the first slice.
                $BytesUploaded = $Upload.StartUpload($UploadId, $s)
                $ctx.ExecuteQuery()

                # fileoffset is the pointer where the next slice will be added.
                $fileoffset = $BytesUploaded.Value

                # You can only start the upload once.
                $first = $false

            }
            Else
            {
                # Get a reference to your file.
                $Upload = $ctx.Web.GetFileByServerRelativeUrl($Docs.RootFolder.ServerRelativeUrl + [System.IO.Path]::AltDirectorySeparatorChar + $UniqueFileName);

                If($last) {

                    # Is this the last slice of data?
                    $s = [System.IO.MemoryStream]::new($lastBuffer)


                    # End sliced upload by calling FinishUpload.
                    $Upload = $Upload.FinishUpload($UploadId, $fileoffset, $s)
                    $ctx.ExecuteQuery()


                    Write-Host "File upload complete"
                    # Return the file object for the uploaded file.
                    return $Upload

                }
                else {

                    $s = [System.IO.MemoryStream]::new($buffer)

                    # Continue sliced upload.
                    $BytesUploaded = $Upload.ContinueUpload($UploadId, $fileoffset, $s)
                    $ctx.ExecuteQuery()

                    # Update fileoffset for the next slice.
                    $fileoffset = $BytesUploaded.Value

                }
            }

        }
    }
    Catch 
    {
        Write-Host $_.Exception.Message -ForegroundColor Red
    }
    Finally 
    {

        if ($Fs -ne $null)
        {
            $Fs.Dispose()
        }

    }
}