背景:
我有以下脚本,该脚本应将一个文件从一个位置复制到另一个位置,还应复制“修改日期”元数据。
除了不复制修改后的日期元数据并在修改后的日期元数据字段/列中显示文件复制的日期/时间之外,其他所有方法均有效:
当我在屏幕上输出源文件的修改日期时,它会显示正确的修改日期,但这似乎并没有应用于新位置的文件。
脚本:
Add-PSSnapin Microsoft.SharePoint.PowerShell -ErrorAction SilentlyContinue
#Variables for Processing
$WebURL="https://sharepoint.oshirowanen.com/sites/oshirodev"
$SourceFile="https://sharepoint.oshirowanen.com/sites/oshirodev/folder1/user1/test.doc"
$TargetLibrary="folder2"
#Get Objects
$Web = Get-SPWeb $WebURL
$SourceFile = $Web.GetFile($SourceFile)
$TargetLibrary = $Web.GetFolder($TargetLibrary)
#Copy the file into the Target library
$File = $TargetLibrary.Files.Add($SourceFile.Name, $SourceFile.OpenBinary(), $true)
#Copy Meta-Data
#METADATA UPDATE DOES NOT WORK
$item = $File.Item
#Original attempt - not working
#$item["Modified"] = $SourceFile.TimeLastModified.ToLocalTime()
#Suggested attempt 2 - not working
#$itemModified = ([DateTime]$SourceFile.Item["Modified"]).DateTime
#$item["Modified"] = $itemModified
#Suggested attempt 2
$File.item["Modified"] = $SourceFile.item["Modified"]
##Check value of sourcefiles modifieddate - shows correct modified date
write-host $SourceFile.item["Modified"]
#Update
$item.UpdateOverwriteVersion()
输出:
但是,写主机显示正确的修改日期:
PS C:\Users\Oshiro\Desktop\scripts> .\MetaData.ps1
10 August 2018 10:00:07
PS C:\Users\Oshiro\Desktop\scripts>
问题:
有人能看到我做错了吗?
出口SPWEB尝试:
脚本:
Export-SPWeb -Identity "https://sharepoint.oshirowanen.com/sites/oshirodev/folder1/user1/" -ItemUrl "lists/Customlist" -Path "c:\sharepoint_export\customlist_export.cmp" -IncludeUserSecurity
错误:
Export-SPWeb : Cannot find an SPWeb object with Id or Url : https://sharepoint.oshirowanen.com/sites/oshirodev/folder1/user1/.
At line:1 char:13
+ Export-SPWeb <<<< -Identity "https://sharepoint.oshirowanen.com/sites/oshirodev/folder1/user1/" -ItemUrl "lists/Customlist" -Path "c:\sharepoint_export\customlist_export.cmp" -IncludeUserSecurity
+ CategoryInfo : InvalidData: (Microsoft.Share...CmdletExportWeb:SPCmdletExportWeb) [Export-SPWeb], SPCmdletPipeBindException
+ FullyQualifiedErrorId : Microsoft.SharePoint.PowerShell.SPCmdletExportWeb
答案 0 :(得分:0)
您的脚本对我来说似乎不错,只应更改一行(这些列通常被视为只读列,但可以修改):
# new_file["Modified"] = original_file["Modified"]
$File.item["Modified"] = $SourceFile.item["Modified"]
您将找到有关此问题的一些主题。有些帖子会告诉您export-spweb
和import-spweb
不会保留诸如创建/修改日期,创建者等之类的项目,而现在不正确。
除了固定线路外,您还可以检查以下内容:
IncludeUserSecurity
通过GUI启用IncludeUserSecurity
。您需要:中央管理控制台上的复选框 / 备份部分-> “导出完全安全性”
-IncludeUserSecurity
。您可以使用包含参数[-IncludeUserSecurity]
的{{3}}和Export-SPWeb编写脚本
Export-SPWeb
仅导出文件列表 如oshirowanen正确指出的那样,您不能使用Export-SPWeb导出单个文件-您只能仅导出:整个站点,列表或库。
我提供了一种导出/导入列表的方法:
通过Export-SPWeb
导出列表(网站集不是root):
Export-SPWeb -Identity "https://sharepoint.oshirowanen.com/sites/oshirodev/folder1/user1/" -ItemUrl "lists/Customlist" -Path "c:\sharepoint_export\customlist_export.cmp" -IncludeUserSecurity
注意:请不要忘记在网站集名称中包含最后一个反斜杠。
(要创建:Import-SPWeb,到a list in SharePoint或通过edit a list创建自定义列表)。
要导入列表应该很简单:
Import-SPWeb "https://sharepoint.oshirowanen.com/sites/oshirodev/folder2/" -Path "c:\sharepoint_export\customlist_export.cmp" -IncludeUserSecurity