无法复制元数据

时间:2018-09-12 10:52:05

标签: powershell sharepoint sharepoint-2010 powershell-v2.0

背景:

我有以下脚本,该脚本应将一个文件从一个位置复制到另一个位置,还应复制“修改日期”元数据。

除了不复制修改后的日期元数据并在修改后的日期元数据字段/列中显示文件复制的日期/时间之外,其他所有方法均有效:

当我在屏幕上输出源文件的修改日期时,它会显示正确的修改日期,但这似乎并没有应用于新位置的文件。


脚本:

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()

输出:

Shows current date as modified date

但是,写主机显示正确的修改日期:

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

1 个答案:

答案 0 :(得分:0)

您的脚本对我来说似乎不错,只应更改一行(这些列通常被视为只读列,但可以修改):

# new_file["Modified"] = original_file["Modified"]
$File.item["Modified"] = $SourceFile.item["Modified"]

您将找到有关此问题的一些主题。有些帖子会告诉您export-spwebimport-spweb不会保留诸如创建/修改日期,创建者等之类的项目,而现在不正确。

除了固定线路外,您还可以检查以下内容:

  • GUI IncludeUserSecurity

通过GUI启用IncludeUserSecurity。您需要:中央管理控制台上的复选框 / 备份部分-> “导出完全安全性”

Export Full Security section

  • 如果您应该使用Export / Import-SPWeb,则有一个选项-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