Cum să transferați fișiere OneDrive către un alt utilizator prin PowerShell

Cum Sa Transferati Fisiere Onedrive Catre Un Alt Utilizator Prin Powershell



Transferul fișierelor din contul dvs. Microsoft OneDrive către un alt utilizator este ușor, în sensul că puteți descărca conținutul de pe OneDrive, apoi le puteți încărca manual în celălalt cont. În această postare, vă vom arăta cum transferați fișiere OneDrive către alt utilizator prin PowerShell .



  Cum să transferați fișiere OneDrive către un alt utilizator prin PowerShell





Lucruri de luat în considerare

Când vine vorba de încărcarea fișierelor din OneDrive într-un alt cont, este o sarcină care va dura ceva timp, deoarece nu este posibil în acest moment să încărcați fișiere mai mari de 250 MB. Vestea bună este că PowerShell va nota toate fișierele pe care nu le poate încărca, astfel încât să le puteți căuta și să le partajați prin metoda obișnuită.





Înainte de a încărca fișierele în celălalt cont OneDrive, fișierele vor fi mai întâi descărcate pe computer, așa că asigurați-vă că aveți suficient spațiu pe hard disk sau SSD înainte de a merge mai departe. Și, deoarece conexiunea dvs. la internet este necesară, viteza totală de transfer va depinde de calitatea rețelei.



Acum, trebuie să remarcăm că autentificarea cu doi factori nu există în contul de administrator, așa că creați un cont de administrator temporar care să nu aibă 2FA numai în acest scop.

Lucruri de care vei avea nevoie

Vom folosi un script special pentru a muta fișierele dintr-un cont OneDrive în altul. Deci, pentru ca scriptul să funcționeze cu probleme, instalați următoarele module PowerShell chiar acum:

Modul SharePoint PnP PowerShell



serviciile audio nu răspund

Deschideți instrumentul PowerShell ca administrator, apoi executați următoarea comandă:

Install-Module SharePointPnPPowerShellOnline -Force

Shell de gestionare SharePoint Online

Scopul acestui instrument este de a modifica permisiunile pentru contul OneDrive al utilizatorilor.

Descărcați și instalați-l gratuit de pe microsoft.com .

Modulul Powershell MSOnline V1

Pentru a instala acest modul final, rulați următoarea comandă în PowerShell ca administrator:

Install-Module MSOnline -Force

Cum să transferați fișiere OneDrive într-un alt cont

Pentru a transfera fișiere din contul OneDrive în altul, trebuie să deschideți PowerShell și apoi să rulați scriptul furnizat.

Deschideți PowerShell

  Căutare Microsoft PowerShell

Deschideți Visual Studio Code sau PowerShell.

Puteți face acest lucru făcând clic pe butonul Căutare, apoi căutați PowerShell.

De acolo, faceți clic dreapta pe aplicație, apoi selectați opțiunea concepută pentru a deschide instrumentul în modul Admin.

Rulați scriptul

  Scriptul OneDrive PowerShell

Apoi, trebuie să rulați scriptul relevant. Îl găsiți în partea de jos a articolului.

Am ales să facem asta pentru că scenariul este destul de lung.

După ce adăugați scriptul, apăsați tasta Enter de pe tastatură.

Transferați fișierele

În cele din urmă, acum este timpul să transferați fișierele într-un alt cont OneDrive.

Vedeți, imediat după ce apăsați tasta Enter, vi se va cere să adăugați contul de e-mail Numele de utilizator al utilizatorului care pleacă .

Veți avea nevoie și de Numele de utilizator al utilizatorului de destinație . Acesta este utilizatorul OneDrive unde vor fi copiate și transferate fișierele.

În cele din urmă, vi se va cere să adăugați Numele de utilizator al administratorului Office 365 .

Așteptați ca scriptul să-și facă treaba înainte de a verifica contul de primire pentru a vedea dacă fișierele au fost transferate corect.

Copiați și lipiți scriptul de mai jos:

$departinguser = Read-Host "Enter departing user's email"
$destinationuser = Read-Host "Enter destination user's email"
$globaladmin = Read-Host "Enter the username of your Global Admin account"
$credentials = Get-Credential -Credential $globaladmin
Connect-MsolService -Credential $credentials
$InitialDomain = Get-MsolDomain | Where-Object {$_.IsInitial -eq $true}
  
$SharePointAdminURL = "https://$($InitialDomain.Name.Split(".")[0])-admin.sharepoint.com"
  
$departingUserUnderscore = $departinguser -replace "[^a-zA-Z]", "_"
$destinationUserUnderscore = $destinationuser -replace "[^a-zA-Z]", "_"
  
$departingOneDriveSite = "https://$($InitialDomain.Name.Split(".")[0])-my.sharepoint.com/personal/$departingUserUnderscore"
$destinationOneDriveSite = "https://$($InitialDomain.Name.Split(".")[0])-my.sharepoint.com/personal/$destinationUserUnderscore"
Write-Host "`nConnecting to SharePoint Online" -ForegroundColor Blue
Connect-SPOService -Url $SharePointAdminURL -Credential $credentials
  
Write-Host "`nAdding $globaladmin as site collection admin on both OneDrive site collections" -ForegroundColor Blue
# Set current admin as a Site Collection Admin on both OneDrive Site Collections
Set-SPOUser -Site $departingOneDriveSite -LoginName $globaladmin -IsSiteCollectionAdmin $true
Set-SPOUser -Site $destinationOneDriveSite -LoginName $globaladmin -IsSiteCollectionAdmin $true
Write-Host "`nConnecting to $departinguser's OneDrive via SharePoint Online PNP module" -ForegroundColor Blue
Connect-PnPOnline -Url $departingOneDriveSite -Credentials $credentials
Write-Host "`nGetting display name of $departinguser" -ForegroundColor Blue
# Get name of departing user to create folder name.
$departingOwner = Get-PnPSiteCollectionAdmin | Where-Object {$_.loginname -match $departinguser}
# If there's an issue retrieving the departing user's display name, set this one.
 if  ($departingOwner -contains $null) {
    $departingOwner = @{
        Title = "Departing User"
    }
}
  
# Define relative folder locations for OneDrive source and destination
$departingOneDrivePath = "/personal/$departingUserUnderscore/Documents"
$destinationOneDrivePath = "/personal/$destinationUserUnderscore/Documents/$($departingOwner.Title)'s Files"
$destinationOneDriveSiteRelativePath = "Documents/$($departingOwner.Title)'s Files"
  
Write-Host "`nGetting all items from $($departingOwner.Title)" -ForegroundColor Blue
# Get all items from source OneDrive
$items = Get-PnPListItem -List Documents -PageSize 1000
$largeItems = $items | Where-Object {[long]$_.fieldvalues.SMTotalFileStreamSize -ge 261095424 -and $_.FileSystemObjectType -contains "File"}
 if  ($largeItems) {
    $largeexport = @()
     foreach  ($item  in  $largeitems) {
        $largeexport += "$(Get-Date) - Size: $([math]::Round(($item.FieldValues.SMTotalFileStreamSize / 1MB),2)) MB Path: $($item.FieldValues.FileRef)"
        Write-Host "File too large to copy: $($item.FieldValues.FileRef)" -ForegroundColor DarkYellow
    }
    $largeexport | Out-file C:\temp\largefiles.txt -Append
    Write-Host "A list of files too large to be copied from $($departingOwner.Title) have been exported to C:\temp\LargeFiles.txt" -ForegroundColor Yellow
}
$rightSizeItems = $items | Where-Object {[long]$_.fieldvalues.SMTotalFileStreamSize -lt 261095424 -or $_.FileSystemObjectType -contains "Folder"}
Write-Host "`nConnecting to $destinationuser via SharePoint PNP PowerShell module" -ForegroundColor Blue
Connect-PnPOnline -Url $destinationOneDriveSite -Credentials $credentials
Write-Host "`nFilter by folders" -ForegroundColor Blue
# Filter by Folders to create directory structure
$folders = $rightSizeItems | Where-Object {$_.FileSystemObjectType -contains "Folder"}
  
Write-Host "`nCreating Directory Structure" -ForegroundColor Blue
 foreach  ($folder  in  $folders) {
    $path = ('{0}{1}' -f $destinationOneDriveSiteRelativePath, $folder.fieldvalues.FileRef).Replace($departingOneDrivePath, '')
    Write-Host "Creating folder in $path" -ForegroundColor Green
    $newfolder = Ensure-PnPFolder -SiteRelativePath $path
}
  
Write-Host "`nCopying Files" -ForegroundColor Blue
$files = $rightSizeItems | Where-Object {$_.FileSystemObjectType -contains "File"}
$fileerrors = ""
foreach ($file in $files) {
    $destpath = ("$destinationOneDrivePath$($file.fieldvalues.FileDirRef)").Replace($departingOneDrivePath, "")
    Write-Host "Copying $($file.fieldvalues.FileLeafRef) to $destpath" -ForegroundColor Green
    $newfile = Copy-PnPFile -SourceUrl $file.fieldvalues.FileRef -TargetUrl $destpath -OverwriteIfAlreadyExists -Force -ErrorVariable errors -ErrorAction SilentlyContinue
    $fileerrors += $errors
}
$fileerrors | Out-File c:\temp\fileerrors.txt
# Remove Global Admin from Site Collection Admin role for both users
Write-Host "`nRemoving $globaladmin from OneDrive site collections" -ForegroundColor Blue
Set-SPOUser -Site $departingOneDriveSite -LoginName $globaladmin -IsSiteCollectionAdmin $false
Set-SPOUser -Site $destinationOneDriveSite -LoginName $globaladmin -IsSiteCollectionAdmin $false
Write-Host "`nComplete!" -ForegroundColor Green

Puteți găsi scenariul pe aceasta Pagina Reddit .

CITIT : Cum să exportați CSV în PowerShell pe Windows

Poate PowerShell să acceseze OneDrive?

SharePoint Online PowerShell va face posibil ca utilizatorii să se conecteze la un alt cont OneDrive folosind instrumentul PowerShell. Vă va cere să introduceți parola pentru ca PowerShell să înceapă să lucreze la conturile dvs. OneDrive prin intermediul cmdlet-urilor.

OneDrive poate fi accesat de utilizatori externi?

Contul dvs. OneDrive poate fi accesat de utilizatori externi, dar numai dacă permiteți acest lucru. Utilizatorii pot avea acces la fișierele dvs. pentru totdeauna sau pentru o perioadă de timp stabilită. De asemenea, puteți limita ceea ce pot face.

Cum să copiați fișiere de pe OneDrive al altei persoane?

Aveți următoarele opțiuni dacă doriți să copiați fișiere de pe OneDrive al altei persoane:

  • Deschideți OneDrive în browser folosind linkul, selectați fișierele pe care doriți să le copiați și faceți clic pe Descărcare. Acesta îl va descărca pe computer.
  • Deschideți contul OneDrive folosind linkul, selectați fișierele pe care doriți să le copiați și faceți clic pe Copiați în.

Asta este!

  Cum să transferați fișiere OneDrive către un alt utilizator prin PowerShell
Posturi Populare