PowerShell ద్వారా OneDrive ఫైల్‌లను మరొక వినియోగదారుకు ఎలా బదిలీ చేయాలి

Powershell Dvara Onedrive Phail Lanu Maroka Viniyogadaruku Ela Badili Ceyali



మీ Microsoft OneDrive ఖాతా నుండి మరొక వినియోగదారుకు ఫైల్‌లను బదిలీ చేయడం సులభం, మీరు మీ OneDrive నుండి కంటెంట్‌ను డౌన్‌లోడ్ చేసుకోవచ్చు, ఆపై వాటిని ఇతర ఖాతాకు మాన్యువల్‌గా అప్‌లోడ్ చేయవచ్చు. ఈ పోస్ట్‌లో, ఎలా చేయాలో మేము మీకు చూపుతాము PowerShell ద్వారా OneDrive ఫైల్‌లను మరొక వినియోగదారుకు బదిలీ చేయండి .



  PowerShell ద్వారా OneDrive ఫైల్‌లను మరొక వినియోగదారుకు ఎలా బదిలీ చేయాలి





పరిగణించవలసిన విషయాలు

మీ OneDrive నుండి మరొక ఖాతాకు ఫైల్‌లను అప్‌లోడ్ చేయడానికి వచ్చినప్పుడు, 250MB కంటే పెద్ద ఫైల్‌లను అప్‌లోడ్ చేయడం ప్రస్తుతం సాధ్యం కానందున ఇది కొంత సమయం పట్టే పని. శుభవార్త ఏమిటంటే పవర్‌షెల్ అప్‌లోడ్ చేయలేని అన్ని ఫైల్‌లను నోట్ చేస్తుంది, కాబట్టి మీరు వాటిని వెతకవచ్చు మరియు సాధారణ పద్ధతి ద్వారా భాగస్వామ్యం చేయవచ్చు.





విండోస్ l పనిచేయడం లేదు

ఇతర OneDrive ఖాతాకు ఫైల్‌లను అప్‌లోడ్ చేయడానికి ముందు, ఫైల్‌లు ముందుగా మీ కంప్యూటర్‌కు డౌన్‌లోడ్ చేయబడతాయి, కాబట్టి ముందుకు వెళ్లడానికి ముందు మీ హార్డ్ డ్రైవ్ లేదా SSDలో మీకు తగినంత స్థలం ఉందని నిర్ధారించుకోండి. మరియు మీ ఇంటర్నెట్ కనెక్షన్ అవసరం కాబట్టి, బదిలీ మొత్తం వేగం నెట్‌వర్క్ నాణ్యతపై ఆధారపడి ఉంటుంది.



ఇప్పుడు, అడ్మినిస్ట్రేటర్ ఖాతాలో రెండు-కారకాల ప్రమాణీకరణ ఉనికిలో లేదని మేము గమనించాలి, కాబట్టి ఈ ప్రయోజనం కోసం మాత్రమే 2FA లేని తాత్కాలిక నిర్వాహక ఖాతాను సృష్టించండి.

మీకు కావలసినవి

మేము ఫైల్‌లను ఒక OneDrive ఖాతా నుండి మరొకదానికి తరలించడానికి ప్రత్యేక స్క్రిప్ట్‌ని ఉపయోగిస్తాము. కాబట్టి, స్క్రిప్ట్ సమస్యలతో పని చేయడానికి, దయచేసి కింది పవర్‌షెల్ మాడ్యూల్‌లను ఇప్పుడే ఇన్‌స్టాల్ చేయండి:

SharePoint PnP PowerShell మాడ్యూల్



పవర్‌షెల్ సాధనాన్ని అడ్మిన్‌గా తెరిచి, కింది ఆదేశాన్ని అమలు చేయండి:

Install-Module SharePointPnPPowerShellOnline -Force

షేర్‌పాయింట్ ఆన్‌లైన్ మేనేజ్‌మెంట్ షెల్

ఈ సాధనం యొక్క ఉద్దేశ్యం వినియోగదారుల వన్‌డ్రైవ్ ఖాతాలోని అనుమతులను సవరించడం.

నుండి ఉచితంగా డౌన్‌లోడ్ చేసి, ఇన్‌స్టాల్ చేయండి microsoft.com .

MSOnline V1 పవర్‌షెల్ మాడ్యూల్

ఈ చివరి మాడ్యూల్‌ను ఇన్‌స్టాల్ చేయడానికి, దయచేసి పవర్‌షెల్‌లో కింది ఆదేశాన్ని అడ్మిన్‌గా అమలు చేయండి:

Install-Module MSOnline -Force

OneDrive ఫైల్‌లను మరొక ఖాతాకు ఎలా బదిలీ చేయాలి

మీ OneDrive ఖాతా నుండి మరొకదానికి ఫైల్‌లను బదిలీ చేయడానికి, మీరు PowerShellని తెరిచి, అందించిన స్క్రిప్ట్‌ను అమలు చేయాలి.

పవర్‌షెల్ తెరవండి

  Microsoft PowerShell శోధన

విజువల్ స్టూడియో కోడ్ లేదా పవర్‌షెల్ తెరవండి.

మీరు శోధన బటన్‌పై క్లిక్ చేయడం ద్వారా దీన్ని చేయవచ్చు, ఆపై PowerShell కోసం శోధించండి.

అక్కడ నుండి, యాప్‌పై కుడి-క్లిక్ చేసి, అడ్మిన్ మోడ్‌లో సాధనాన్ని తెరవడానికి రూపొందించిన ఎంపికను ఎంచుకోండి.

ట్విట్టర్ కోసం సైన్ అప్ చేయలేరు

స్క్రిప్ట్‌ని అమలు చేయండి

  OneDrive PowerShell స్క్రిప్ట్

తరువాత, మీరు తప్పనిసరిగా సంబంధిత స్క్రిప్ట్‌ను అమలు చేయాలి. మీరు దానిని వ్యాసం దిగువన కనుగొనవచ్చు.

స్క్రిప్ట్ చాలా పొడవుగా ఉన్నందున మేము దీన్ని ఎంచుకున్నాము.

స్క్రిప్ట్‌ని జోడించిన తర్వాత, మీ కీబోర్డ్‌లోని ఎంటర్ కీని నొక్కండి.

ఫైళ్లను బదిలీ చేయండి

చివరగా, ఇప్పుడు ఫైల్‌లను మరొక OneDrive ఖాతాకు బదిలీ చేయడానికి సమయం ఆసన్నమైంది.

మీరు చూడండి, ఎంటర్ కీని నొక్కిన వెంటనే, మీరు ఇమెయిల్ ఖాతాను జోడించమని అడగబడతారు నిష్క్రమించే వినియోగదారు యొక్క వినియోగదారు పేరు .

మీకు కూడా అవసరం అవుతుంది గమ్యస్థాన వినియోగదారు యొక్క వినియోగదారు పేరు . ఫైల్‌లు కాపీ చేయబడి, బదిలీ చేయబడే OneDrive వినియోగదారు ఇది.

చివరగా, మీరు జోడించమని అడగబడతారు మీ Office 365 అడ్మిన్ యొక్క వినియోగదారు పేరు .

ఫైల్‌లు సరిగ్గా బదిలీ చేయబడిందో లేదో చూడటానికి స్వీకరించే ఖాతాను తనిఖీ చేయడానికి ముందు స్క్రిప్ట్ దాని పనిని చేసే వరకు వేచి ఉండండి.

కింది స్క్రిప్ట్‌ని కాపీ చేసి పేస్ట్ చేయండి:

$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

మీరు దీనిపై స్క్రిప్ట్‌ను కనుగొనవచ్చు రెడ్డిట్ పేజీ .

చదవండి : Windowsలో PowerShellలో CSVని ఎలా ఎగుమతి చేయాలి

PowerShell OneDriveని యాక్సెస్ చేయగలదా?

SharePoint ఆన్‌లైన్ PowerShell వినియోగదారులు PowerShell సాధనాన్ని ఉపయోగించి మరొక OneDrive ఖాతాకు కనెక్ట్ చేయడాన్ని సాధ్యం చేస్తుంది. cmdlets ద్వారా PowerShell మీ OneDrive ఖాతాలపై పని చేయడం ప్రారంభించడానికి ఇది మీ పాస్‌వర్డ్‌ను ఇన్సర్ట్ చేయమని అడుగుతుంది.

బాహ్య వినియోగదారులు OneDriveని యాక్సెస్ చేయవచ్చా?

మీ OneDrive ఖాతాను బాహ్య వినియోగదారులు యాక్సెస్ చేయవచ్చు, కానీ మీరు అనుమతిస్తే మాత్రమే. వినియోగదారులు మీ ఫైల్‌లను ఎప్పటికీ లేదా నిర్ణీత వ్యవధిలో యాక్సెస్ చేయగలరు. మీరు వారు ఏమి చేయగలరో కూడా పరిమితం చేయవచ్చు.

మరొక వ్యక్తి యొక్క OneDrive నుండి ఫైల్‌లను ఎలా కాపీ చేయాలి?

మీరు మరొక వ్యక్తి యొక్క OneDrive నుండి ఫైల్‌లను కాపీ చేయాలనుకుంటే మీకు ఈ క్రింది ఎంపికలు ఉన్నాయి:

  • లింక్‌ని ఉపయోగించి మీ బ్రౌజర్‌లో OneDriveని తెరిచి, మీరు కాపీ చేయాలనుకుంటున్న ఫైల్‌లను ఎంచుకుని, డౌన్‌లోడ్ క్లిక్ చేయండి. ఇది మీ కంప్యూటర్‌కు డౌన్‌లోడ్ చేస్తుంది.
  • లింక్‌ని ఉపయోగించి OneDrive ఖాతాను తెరిచి, మీరు కాపీ చేయాలనుకుంటున్న ఫైల్‌లను ఎంచుకుని, కాపీ చేయి క్లిక్ చేయండి.

అంతే!

ఇటానియం ఆధారిత వ్యవస్థలు
  PowerShell ద్వారా OneDrive ఫైల్‌లను మరొక వినియోగదారుకు ఎలా బదిలీ చేయాలి
ప్రముఖ పోస్ట్లు