对数组或哈希表的SQL查询

时间:2018-03-05 19:36:50

标签: arrays powershell hashtable

有没有人有一种创造性的方法来处理多维数组或散列表,就像数据库表一样,你可以对它执行简单的SELECT-WHERE,SUM,COUNT和GROUP-BY或等效查询?

以下是我想要解析为不同的摘要文件的一些示例数据。我查看每行上的第一个字段,并对从SD开始的行中的数据进行分组或求和。我不知道自己应该投入多少细节,但事实并非如此,我还不知道PS还能让我的剧本变得性感:

OH;1;ACME Inc;Arlington,VA 22204,USA;CSV;wiley@acme.inc;2018-01-07;;8074688;
SD;2;8074688;M/C;2018-01-05;00000523094871;04.01.18;04.01.18;2804,00;35,34;2768,66;6;89005257251;;;
SD;3;8074688;VISA;2018-01-05;00000523085587;05.01.18;05.01.18;1070,00;13,48;1056,52;1;91005299658;;;
SD;4;8074688;VISA;2018-01-05;00000523088281;05.01.18;05.01.18;3850,00;48,51;3801,49;4;91005299661;;;
SD;5;8074688;M/C;2018-01-05;00000523088281;05.01.18;05.01.18;1100,00;13,86;1086,14;2;91005299667;;;
SD;6;8074688;MSTO;2018-01-05;00000523088281;05.01.18;05.01.18;1100,00;13,86;1086,14;1;91005299671;;;
SD;7;8074688;MCDE;2018-01-05;00000523091962;04.01.18;04.01.18;46,00;0,58;45,42;1;91005299674;;;
SD;8;8074688;VISA;2018-01-05;00000524454189;02.01.18;04.01.18;900,00;11,32;888,68;19;91005299677;;;
SD;9;8074688;M/C;2018-01-05;00000524454189;02.01.18;04.01.18;420,00;5,29;414,71;9;91005299698;;;
SD;10;8074688;MSTO;2018-01-05;00000524454189;03.01.18;03.01.18;290,00;3,66;286,34;4;91005299709;;;
SD;11;8074688;VISA;2018-01-05;00000523082217;05.01.18;05.01.18;500,00;6,30;493,70;1;91005702322;;;
SD;12;8074688;M/C;2018-01-05;00000523082217;05.01.18;05.01.18;300,00;3,78;296,22;1;91005702325;;;
SD;13;8074688;VISA;2018-01-05;00000523087382;05.01.18;05.01.18;1116,00;14,06;1101,94;3;91005702328;;;
SD;14;8074688;M/C;2018-01-05;00000523087382;05.01.18;05.01.18;1840,00;23,19;1816,81;5;91005702333;;;
BD;15;8074688;;2018-01-07;0111800705600;15336,00;193,23;15142,77;57;;
TD;16;8074688;M/C;;00000523094 871;;;;89005257251; 
TD;17;8074688;MC CONS CR;2018-01-04;143954;;X9235;500,00;89005257251; 
TD;18;8074688;MC CONS CR;2018-01-04;150906;;X2107;52,00;89005257251; 
TD;19;8074688;MC CONS CR;2018-01-04;153840;;X6804;1000,00;89005257251; 
TD;20;8074688;MC CONS CR;2018-01-04;173636;;X2107;52,00;89005257251; 
TD;21;8074688;MC CONS CR;2018-01-04;193801;;X1042;200,00;89005257251; 
TD;22;8074688;MC CONS CR;2018-01-04;223605;;X3268;1000,00;89005257251;

1 个答案:

答案 0 :(得分:2)

您提供的样本是带有分号分隔符的CSV。

要理解的关键概念是PowerShell处理对象。试试这个:

 $test = "some string"
 $test.Length          # returns 11

您不必告诉PowerShell字符串的长度;它是字符串对象的属性。

类似地:

$test2 = @("some string","some other string")
$test2.Count           # returns 2

回到您的数据,您可以使用Import-Csv

将其导入PowerShell
$myData = Import-Csv -Path "c\path\to\your\file.txt" -Delimiter ";"

请记住这会抱怨缺少标题。因为你的第一行字段少于其他大多数行,不是因为它识别出它不是标题;默认情况下,Import-Csv将假定第一行是标题。您可以使用-Header参数指定标头,如上面链接中所述。

变量$myData的类型为PSCustomObject。您可以使用Get-Content并将数据操作到数组或哈希表中......但为什么呢? Import-Csv为您提供了一个很好的对象,其中的字段可以NoteProperties显示:

$myData.OH   # prints off the first column, assuming a header is not provided.

要以与我已经在SQL中做过的方式相同的方式操作数据,您需要熟悉PowerShell提供的功能。所以这里有一些RTFM链接可以帮助您入门;-p