在PowerShell中将二维数组写入Excel范围对象的Value2属性

时间:2012-10-17 15:27:24

标签: excel powershell powershell-v2.0

我是PowerShell的新手,似乎无法弄清楚为什么下面代码中的第一种方法不起作用,而第二种方法(注释掉)则不行。

我正在尝试将数据库记录集的结果写入Excel文件,因此我需要一个动态可扩展的数组。我知道如何使用第一种类型的数组,而不是第二种类型。

如果出现问题,我的问题就解决了:

代码:

#need this to work around bug if you have a non us-locale and English excel: http://support.microsoft.com/default.aspx?scid=kb;en-us;320369
[System.Threading.Thread]::CurrentThread.CurrentCulture = "en-US" 

# This doesn't work
$values = @(('test1','test2'),('test3','test4'))

# This works
<#
$values = New-Object 'object[,]' 2,2
$values[0,0] = 'test1'
$values[0,1] = 'test2'
$values[1,0] = 'test3'
$values[1,1] = 'test4'
#>

$excel = New-Object -ComObject Excel.Application
$excel.Visible = $False
$xls_workbook = $excel.Workbooks.Add()
$range = $xls_workbook.sheets.item(1).Range("A1:B2")
$range.Value2 = $values

$xls_workbook.SaveAs($MyInvocation.MyCommand.Definition.Replace($MyInvocation.MyCommand.Name, "") + "test.xlsx")
$excel.Quit()

2 个答案:

答案 0 :(得分:1)

当我得到两个变量的类型时:

$values1.GetType() 
$values2.GetType()

这就是我得到的:

IsPublic IsSerial Name                                     BaseType                                                                                                               
-------- -------- ----                                     --------                                                                                                               
True     True     Object[]                                 System.Array                                                                                                           
True     True     Object[,]                                System.Array   

所以$ values1是一维的,$ values2是二维的。这里有一个相关的问题:

Powershell Multidimensional Arrays

答案 1 :(得分:1)

**Object[]**是锯齿状数组或数组数组

**Object[,]**是二维数组。

差异"in nutshell"

还有How to convert jagged>2d arrays