背景:
我有以下脚本,该脚本应将一个文件从一个位置复制到另一个位置,并且还应复制“修改日期”元数据。
除了不复制修改后的日期元数据,并在修改后的日期元数据字段/列中显示文件复制的日期/时间之外,所有其他方法均有效:
当我将源文件的修改日期输出到屏幕时,它会显示正确的修改日期,但似乎并没有应用到新位置的文件中。
脚本:
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
最佳答案
您的脚本对我来说似乎很好,只应更改一行(这些列通常被认为是只读的,但可以修改):
# new_file["Modified"] = original_file["Modified"]
$File.item["Modified"] = $SourceFile.item["Modified"]
您将找到有关此问题的一些主题。有些帖子会告诉您
export-spweb
和import-spweb
不保留诸如创建/修改日期,创建者等之类的项目,而现在这是不正确的。除了修复生产线,您还可以检查以下内容:
IncludeUserSecurity
通过GUI启用
IncludeUserSecurity
。您需要:管理中心控制台/“备份”部分上的复选框->“导出完全安全性”-IncludeUserSecurity
选项。 您可以使用Export-SPWeb和Import-SPWeb编写脚本,它们确实包含参数
[-IncludeUserSecurity]
编辑-由于注释-使用
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
注意:不要忘记在网站集名称中包含最后一个反斜杠。
(要创建:a list in SharePoint,edit a list或通过Sharepoint designer创建自定义列表)。
导入列表应该很简单:
Import-SPWeb "https://sharepoint.oshirowanen.com/sites/oshirodev/folder2/" -Path "c:\sharepoint_export\customlist_export.cmp" -IncludeUserSecurity