标题: [问题求助] 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
- #@&cls&powershell "type %~s0|out-string|iex"&exit
- $a=gc -readcount 0 D:\UTF16.txt
- $b=(($a[-1..-500] -match '企业 ')[0] -split ' ')[5,6] -jion '|'
- $f=0
- 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 - #@&cls&powershell "type %~s0|out-string|iex"&pause
- $a=gc -readcount 0 UTF16.txt
- $b=(($a[-1..-500] -match '企业 ')[0] -split ' ')[6,7] -jion '|'
- $f=0
- 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}})
- start out.txt
复制代码
仔细试了几次 返回了一些信息- iex : 所在位置 行:3 字符: 53
- + $b=(($a[-1..-500] -match '企业 ')[0] -split ' ')[6,7] -jion '|'
- + ~~~~~
- 表达式或语句中包含意外的标记“-jion”。
- 所在位置 行:3 字符: 59
- + $b=(($a[-1..-500] -match '企业 ')[0] -split ' ')[6,7] -jion '|'
- + ~~~
- 表达式或语句中包含意外的标记“'|'”。
- 所在位置 行:1 字符: 53
- + ~~~
- + CategoryInfo : ParserError: (:) [Invoke-Expression], ParseException
- + 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列没有 ( 这个符号 则正常- #@&cls&powershell "type %~s0|out-string|iex"&exit
- $a=gc -readcount 0 UFT16.txt
- $b=(($a[-1..-500] -match '企业 ')[0] -split ' ')[6,7]
- $f=0
- 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}})
- start out.txt
复制代码
第7列刚好有 ( 这个符号
如果有 ( 这个符号 不正常了 输出结果为空 似乎不能匹配 ( 这个符号
-match ".*$b" 这里是否需要修改适应 ( 这个符号呢
作者: idwma 时间: 2023-7-22 21:17
- #@&cls&powershell "type %~s0|out-string|iex"&exit
- $a=gc -readcount 0 UFT16.txt
- $b=(($a[-1..-500] -match '企业 ')[0] -split ' ')[6,7] -join ' '
- $f=0
- 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}})
- 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 |