我正在尝试创建有关Exchange 2010邮箱大小的简单报告。
虽然这有效:
Get-MailboxStatistics -server <serverfqdn> |ft displayname, TotalItemSize
这不会(第二列保持空白):
Get-MailboxStatistics -server <serverfqdn> |ft displayname, {$_.TotalItemSize.Value.ToBytes()}
问题是我需要将大小作为整数,因此第一行代码不符合我的目的。 根据几个网站,第二行代码应工作,但不幸的是我的机器上没有。
我知道我可以在使用第一行后解析该值,但这会不必要地效率低下,不是吗? : - )
希望任何人都可以提供帮助。
此致 凯文
答案 0 :(得分:2)
这对我有用
$a = get-mailbox -id user | Get-MailboxStatistics
$a.TotalItemSize.Value.ToMB()
$a.TotalItemSize.Value.ToKB()
答案 1 :(得分:2)
如果从导入的PS会话执行,则类型变为自定义对象时,方法.ToMB()将丢失。 $ variable.TotalItemSize.Value变为两个元素数组[0],以KB,MB或GB为单位,[1]总是以字节为单位。
因此,为了使用这个,我们可以使用字符串来实现我们想要的东西..为了清晰起见,我们可以长期使用
$mailboxes = Get-Mailbox -Filter{(RecipientType -eq "UserMailbox") -and (CustomAttribute12 -eq "whatever")}
foreach ($mailbox in $mailboxes)
{
$size1 = Get-MailboxStatistics $mailbox.id
[string]$bob = $size1.TotalItemSize.Value
[int]$bill = $bob.TrimEnd(" bytes)").Split("(")[1] # The bytes part of the array.
$bill = $bill/1mb # Convert into MB's
if ($bill -le 1500) {do something} Else {"Too Big " + $bill} # note -le 1500 NOT 1500MB
}
我希望这会有所帮助
答案 2 :(得分:1)
我有同样的问题。我不确定你是否解决了这个问题。 我有这个,这很难看 - 但是有效:
$a = get-mailbox USER | get-mailboxstatistics
$intTotalItemSize = [int]$a.TotalItemSize.SubString($a.TotalItemSize.indexof("(")+1, $a.TotalItemSize.indexof(" b")-$a.TotalItemSize.indexof("("))
答案 3 :(得分:0)
尝试使用此尺寸表达式:
@{expression={$_.TotalItemSize.Value.ToMB()};label="Mailbox Size(MB)"}
我相信还有ToKB()
方法。
答案 4 :(得分:0)
MVP Shay Levy在他的博客上深入研究过这个问题(http://blogs.microsoft.co.il/blogs/scriptfanatic/archive/2011/08/22/get-full-control-over-your-exchange-远程的powershell-session.aspx)。
基本上,您必须修改要远程连接的服务器上的PowerShell虚拟目录中的设置。
对于那些远程访问Exchange服务器的人来说,这是一个好消息,但是对于那些使用托管Exchange解决方案并且无法更改这些设置的人来说,这对我们这些人没有帮助。我想我们将不得不放弃PowerShell的一些超级酷,然后回到解析字符串以获取字节并从那里转换。
- 编辑 -
这就是我处理输出所有用户邮箱大小的文件的方法。它可以进一步压缩,但这种方式更具可读性。
$allMailboxes = Get-Mailbox -ResultSize Unlimited
ForEach ( $mailbox in $allMailboxes ) {
$itemSizeString = ( Get-MailboxStatistics $mailbox.Identity ).TotalItemSize.Value.ToString()
$posOpenParen = $itemSizeString.IndexOf("(") + 1
$numCharsInSize = $itemSizeString.IndexOf(" bytes") - $posOpenParen
$mailboxSizeInBytes = $itemSizeString.SubString($posOpenParen,$numCharsInSize).Replace(",","")
Write-Output "$($mailbox.alias),$($mailboxSizeInBytes)"
}
答案 5 :(得分:0)
Get-Mailbox | Get-MailboxStatistics | Add-Member -MemberType ScriptProperty -Name TotalItemSizeinMB -Value {$this.totalitemsize.value.ToMB()} -PassThru | Format-Table DisplayName,TotalItem*
答案 6 :(得分:0)
我需要在远程会话之外完成这项工作,所以我将Greybear的答案简化为:
$a = get-mailbox USER | get-mailboxstatistics
$intTotalItemSize = [int64]($a.TotalItemSize -split '[\( ]')[3]
或者以原始问题的格式::
Get-MailboxStatistics -Server <serverfqdn> | Select-Object -Property DisplayName,@{label="TotalItemSize";expression={[int64]($_.TotalItemSize -split '[\( ]')[3]}} | ft
意识到[int]对于超过4GB的邮箱会失败,因此更改为[int64]。或者,以MB为单位显示邮箱:
Get-MailboxStatistics -Server <serverfqdn> | Select-Object -Property DisplayName,@{label="TotalItemSize";expression={[int64](([int64]($_.TotalItemSize -split '[\( ]')[3])/1048576)}} | ft
答案 7 :(得分:0)
名称需要在表达式之前。这将有效。
Get-MailboxStatistics -Identity [name] | select @{label=”User”;expression={$_.DisplayName}},lastlogontime,@{label=”Total Size (MB)”;expression={$_.TotalItemSize.Value.ToMB()}}
答案 8 :(得分:0)
这对我有用
@{Name="TotalSize (MB)"; Expression={((($_.TotalItemSize) -split " ")[0])}}
答案 9 :(得分:-1)
您可以尝试:
get-mailbox -resultsize unlimited | Get-MailboxStatistics | ft displayname,@{label="Total Size (MB)";expression={$_.TotalItemSize.Value.ToMB()}}