1

我有一个脚本,可以将所有列表和库中的所有项目/文件输出到 CSV。此外,它还显示项目/文件的当前和以前版本。这还显示了哪个用户修改了每个版本的文件,还显示了每个版本修改文件的日期/时间:

function Get-DocInventory([string]$siteUrl) {
$web = Get-SPWeb "http://contoso.com/sites/Depts3/HBG"
foreach ($list in $web.Lists) {


foreach ($item in $list.Items) {
foreach($version in $item.Versions){
$data = @{
"Version" = $version.VersionLabel
"List Name" = $list.Title
"Created By" = $item["Author"]
"Created Date" = ($item["Created"] -as [datetime]).DateTime
"Modified By" = $version["Editor"]
"Modified Date" = ($version["Modified"] -as [datetime]).DateTime
"Item Name" = $item.Name

}
New-Object PSObject -Property $data | Select "List Name", "Item Name", "Version", "Created By", "Created Date", "Modified By", "Modified Date"
}
}
$web.Dispose();
}
}




Get-DocInventory  | Export-Csv -NoTypeInformation -Path C:\GenerateReport.csv

以下是脚本输出的示例:

在此处输入图像描述

下面是我在访问 Lions.pdf 文件的版本历史时看到的一个 excel 示例:

在此处输入图像描述

我有两个问题:

  • 修改者列显示不需要的电子邮件和域用户名。
  • 我的脚本将“修改日期”列显示为提前 5 小时。Lions.pdf 版本 1 的脚本输出显示时间为上午 11:23。但是当我转到 Lions.pdf 的版本历史时,它说版本 1 在上午 6:23 被修改。时间差异与提前 5 小时相同,这是不正确的。

我似乎无法弄清楚我在这里做错了什么。有人可以帮助解决我遇到的问题吗?我主要关心的是时间,我将不胜感激任何帮助。

4

1 回答 1

1

用户字段

通常在服务器端代码中,使用数组表示法(例如)访问用户字段值myItem["Author"]将返回一个您将转换为适当类型(Microsoft.SharePoint.SPFieldUserValue)的对象。然而,Powershell 会自动将这些值转换为字符串,这就是为什么你会得到不需要的值。

幸运的是,有办法解决它!首先,将字段本身作为对象获取,然后将字段值传递给字段的GetFieldValue()方法。

$userField = $item.Fields.GetField("Author");
$authorObject = $userField.GetFieldValue($item["Author"]);

然后,您将拥有一个具有属性的对象,您可以访问这些属性来检索所需的值,例如LookupValue用户在网站上的显示名称。

$authorName = $authorObject.LookupValue;

日期字段

日期字段稍微容易一些,因为 Powershell 实际上会将它们作为 DateTime 对象交给您。

要格式化 DateTime 对象,您只需调用.ToString()并传入一个指示所需格式的参数。

$data = @{
    ...
    "Modified Date" = $item["Modified"].ToString("MM/dd/yyyy h:mm tt");
    ...
}

时间差异

这很可能归因于您当地的时区。通过浏览器在 SharePoint 网站上显示的时间由您 PC 的时区设置决定。实际保存到 SharePoint 基础数据库的时间由服务器的时区设置决定。

要协调它们,您可以使用 DateTime 对象的.ToUniversalTime()方法以 UTC 时间获取相应的 DateTime 对象(并且可以根据需要将其偏移,直到它与本地时区和夏令时调整对齐)。

编辑:我猜你是在美国东部时间(UTC-5),它会为你提供 UTC 时间的结果(世界协调时间,除了夏令时之外,比你早 5 小时)。您应该能够手动抵消时间来解决这个问题。

$localOffset = -5;
$modified = $version["Modified"] -as [datetime];
if($modified.IsDaylightSavingTime()){$localOffset += 1;}
$modifiedLocal = $modified.addHours(-$localOffset);
于 2015-11-04T16:55:41.903 回答