Board logo

标题: [问题求助] PowerShell脚本-split 多个列 [打印本页]

作者: 娜美    时间: 2023-7-22 14:32     标题: PowerShell脚本-split 多个列

iidwma哥哥   如果是split列数同时增加支持多个列
那么是这样写吗?  偿写不同写法, 但似乎都不对

$b=(($a[-1..-500] -match '企业 ')[0] -split ' ')[5][6]

$b=(($a[-1..-500] -match '企业 ')[0] -split ' ')[5,6]
作者: idwma    时间: 2023-7-22 17:19

  1. #@&cls&powershell "type %~s0|out-string|iex"&exit
  2. $a=gc -readcount 0 D:\UTF16.txt
  3. $b=(($a[-1..-500] -match '企业 ')[0] -split ' ')[5,6] -jion '|'
  4. $f=0
  5. sc D:\out.txt $(foreach($i in $a){if(($f -eq 0) -and $i -match "简名:.*?($b)"){$i;$f=1}elseif(($f -eq 1) -and $i -match '已执行'){$f=0;$i,''}elseif($f -eq 1){$i}})
复制代码

作者: 娜美    时间: 2023-7-22 18:10

本帖最后由 娜美 于 2023-7-22 18:25 编辑

回复 2# idwma
  1. #@&cls&powershell "type %~s0|out-string|iex"&pause
  2. $a=gc -readcount 0 UTF16.txt
  3. $b=(($a[-1..-500] -match '企业 ')[0] -split ' ')[6,7] -jion '|'
  4. $f=0
  5. sc out.txt $(foreach($i in $a){if(($f -eq 0) -and $i -match "简名:.*?($b)"){$i;$f=1}elseif(($f -eq 1) -and $i -match '已执行'){$f=0;$i,''}elseif($f -eq 1){$i}})
  6. start out.txt
复制代码
仔细试了几次   返回了一些信息
  1. iex : 所在位置 行:3 字符: 53
  2. + $b=(($a[-1..-500] -match '企业 ')[0] -split ' ')[6,7] -jion '|'
  3. +                                                     ~~~~~
  4. 表达式或语句中包含意外的标记“-jion”。
  5. 所在位置 行:3 字符: 59
  6. + $b=(($a[-1..-500] -match '企业 ')[0] -split ' ')[6,7] -jion '|'
  7. +                                                           ~~~
  8. 表达式或语句中包含意外的标记“'|'”。
  9. 所在位置 行:1 字符: 53
  10. +                                                     ~~~
  11.     + CategoryInfo          : ParserError: (:) [Invoke-Expression], ParseException
  12.     + FullyQualifiedErrorId : UnexpectedToken,Microsoft.PowerShell.Commands.InvokeExpressionCommand
复制代码

作者: idwma    时间: 2023-7-22 18:47

错了是-join
作者: 娜美    时间: 2023-7-22 20:26

本帖最后由 娜美 于 2023-7-23 13:51 编辑

回复 4# idwma

idwma哥哥 差不多对了

我偿试很多
但如果第7列没有 ( 这个符号  则正常
  1. #@&cls&powershell "type %~s0|out-string|iex"&exit
  2. $a=gc -readcount 0 UFT16.txt
  3. $b=(($a[-1..-500] -match '企业 ')[0] -split ' ')[6,7]
  4. $f=0
  5. sc out.txt $(foreach($i in $a){if(($f -eq 0) -and $i -match ".*$b"){$i;$f=1}elseif(($f -eq 1) -and $i -match '已执行'){$f=0;$i,''}elseif($f -eq 1){$i}})
  6. start out.txt
复制代码
第7列刚好有 ( 这个符号      
如果有 ( 这个符号  不正常了  输出结果为空   似乎不能匹配 (  这个符号

-match ".*$b"    这里是否需要修改适应  ( 这个符号呢
作者: idwma    时间: 2023-7-22 21:17

  1. #@&cls&powershell "type %~s0|out-string|iex"&exit
  2. $a=gc -readcount 0 UFT16.txt
  3. $b=(($a[-1..-500] -match '企业 ')[0] -split ' ')[6,7] -join ' '
  4. $f=0
  5. sc out.txt $(foreach($i in $a){if(($f -eq 0) -and $i -match ".*$([regex]::escape($b))"){$i;$f=1}elseif(($f -eq 1) -and $i -match '已执行'){$f=0;$i,''}elseif($f -eq 1){$i}})
  6. start out.txt
复制代码

作者: 娜美    时间: 2023-7-22 22:47

本帖最后由 娜美 于 2023-7-23 13:53 编辑

回复 6# idwma


    嗯这个可以  今天细测正确,      

谢谢 idwma哥




欢迎光临 批处理之家 (http://bbs.bathome.net/) Powered by Discuz! 7.2