有没有人有一种创造性的方法来处理多维数组或散列表,就像数据库表一样,你可以对它执行简单的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;
答案 0 :(得分:2)
您提供的样本是带有分号分隔符的CSV。
要理解的关键概念是PowerShell处理对象。试试这个:
$test = "some string"
$test.Length # returns 11
您不必告诉PowerShell字符串的长度;它是字符串对象的属性。
类似地:
$test2 = @("some string","some other string")
$test2.Count # returns 2
回到您的数据,您可以使用Import-Csv
:
$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