对数组或哈希表的SQL查询

问题描述 投票:-1回答:1

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

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

OH;1;ACME Inc;Arlington,VA 22204,USA;CSV;[email protected];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;
arrays powershell hashtable
1个回答
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

© www.soinside.com 2019 - 2024. All rights reserved.