Board logo

标题: [问题求助] PowerShell如何用正则取=后面的字符? [打印本页]

作者: 5i365    时间: 2021-10-31 13:08     标题: PowerShell如何用正则取=后面的字符?

_$abctitle_大中国=小日本, 美国佬!
_$cdectitl_大中华=小日本, 英国佬!

把上面两行存成 test.txt, 用powershell =后面的内容

期待的结果:
使用包含 _$abctitle_ 的正则表达式, 获取 第一行 = 后面的 小日本, 美国佬!
同理:
使用包含 _$cdectitl_ 的正则表达式, 获取 第二行 = 后面的 小日本, 英国佬!

自己写了下面的powershell 脚本, 但是取不到值, 求高手指点, 感谢!
-----------------------------------------
(type -Encoding UTF8 "C:\Users\Administrator\Desktop\test.txt") -match '[^_$abctitle_(.*)]=(.+)'
$matches
作者: 5i365    时间: 2021-10-31 14:17

[^_$abctitle_(.*)]=(.+)$   这样把  国=小日本, 英国佬!  干掉了, 但是  国=  字怎样搞掉
作者: xp3000    时间: 2021-10-31 15:17

(?<=_\$abctitle_...=).+$
作者: 5i365    时间: 2021-10-31 15:26

回复 3# xp3000


    感谢, 我是在Powershell中匹配的, 试了下,取不到值, 您的应该是批处理要用的?
作者: 5i365    时间: 2021-10-31 15:29

本帖最后由 5i365 于 2021-10-31 15:47 编辑

回复 3# xp3000


(type -Encoding UTF8 "C:\Users\Administrator\Desktop\test.txt") -match '[^_$title_(.*)]=(.+)'
$matches
作者: xp3000    时间: 2021-10-31 15:36

我用的是软件,支持正则的很多都支持,除了早期的
EmEditor
作者: idwma    时间: 2021-10-31 15:59

  1. (type -Encoding UTF8 "C:\Users\Administrator\Desktop\test.txt") -match "^_$abctitle_.*=(.+)"
复制代码

作者: 5i365    时间: 2021-10-31 16:03

本帖最后由 5i365 于 2021-10-31 16:05 编辑

回复 7# idwma


感谢, 执行结果是 那两行完全输出了
正则中包含_$abctitle_
那就取包含_$abctitle_ 的那行中=后面的内容,即   小日本, 美国佬!   这几个字,
作者: 5i365    时间: 2021-10-31 16:06

回复 7# idwma


    如正则表达式中包含 _$cdectitl_
那就取
小日本, 英国佬!
作者: 5i365    时间: 2021-10-31 16:33

回复 7# idwma


    (@'
_$abctitle_大中国=小日本, 美国佬!
_$cdectitl_大中华=小日本, 英国佬!
'@) -match '[^_$abctitle_(.*)]=(.+)'
$matches
------------------------------------------------
用上面的方式还能取到值, 但是有两个值,
但是用下面的方法却取不了
------------------------------------------------
(type -Encoding UTF8 "C:\Users\Administrator\Desktop\test.txt") -match '[^_$abctitle_(.*)]=(.+)'
作者: idwma    时间: 2021-10-31 17:04

  1. foreach($a in (type test.txt)){if($a -match "^_$abctitle_.*=(.+)"){$matches[1]}}
复制代码

作者: 5i365    时间: 2021-10-31 17:07

回复 11# idwma


    运行后没有值
作者: 5i365    时间: 2021-10-31 17:11

回复 11# idwma


    用批处理如何实现从 test.txt中,
取包含 _$abctitle_  所在行的 = 后面的字符
取包含 _$cdectitl_  所在行的 = 后面的字符
作者: idwma    时间: 2021-10-31 17:23

回复 13# 5i365
  1. foreach($a in (type test.txt)){if($a -match "^_[$]abctitle_.*=(.+)"){$matches[1]}}
复制代码

作者: 5i365    时间: 2021-10-31 17:35

回复 14# idwma


    还是不行, 转义 符 用 ` 也不行
作者: idwma    时间: 2021-10-31 17:42

回复 15# 5i365
  1. ((type test.txt) -match "_[$](abctitle|cdectitl)_") -replace "^.*=",""
复制代码

作者: 5i365    时间: 2021-10-31 17:44

回复 16# idwma


    输出值是:

_$abctitle_澶т腑鍥?灏忔棩鏈? 缇庡浗浣?
_$cdectitl_澶т腑鍗?灏忔棩鏈? 鑻卞浗浣?
作者: idwma    时间: 2021-10-31 17:53

本帖最后由 idwma 于 2021-10-31 18:28 编辑

回复 17# 5i365

测了是可以的呀
作者: 5i365    时间: 2021-10-31 18:39

回复 18# idwma


    刚试了一下, 要把test.txt的编码格式改为ansi 才可以

感觉可能还有更简单的办法
作者: 5i365    时间: 2021-10-31 18:42

回复 18# idwma


    用这种办法 我需要先把_$abctitle_ 先改成 _[$](abctitle)_  这样才可以
作者: 523066680    时间: 2021-10-31 21:28     标题: 串个频道

本帖最后由 523066680 于 2021-10-31 22:03 编辑
  1. use utf8;
  2. use Encode;
  3. my $str='
  4. _$abctitle_大中国=小日本, 美国佬!
  5. _$cdectitl_大中华=小日本, 英国佬!';
  6. while ( $str =~ /_\$\w+_[^=]*=(.+)$/gm) { print encode('gbk', $1),"\n" }
复制代码
Perl, 保存为 utf-8 执行

结果按GBK输出
  1. 小日本, 美国佬!
  2. 小日本, 英国佬!
复制代码

作者: 5i365    时间: 2021-11-1 06:45

回复 21# 523066680


    牛, 如果能在Powershell中用正则直接取就好了
作者: Batcher    时间: 2021-11-1 09:50

回复 1# 5i365


http://bcn.bathome.net/s/tool/index.html?key=sed
  1. type 1.txt | find "_$abctitle_" | sed "s/.*=//" >2.txt
  2. type 1.txt | find "_$cdectitl_" | sed "s/.*=//" >3.txt
复制代码

作者: Batcher    时间: 2021-11-1 09:51

回复 1# 5i365


2.bat
  1. @echo off
  2. for /f "tokens=2 delims==" %%i in ('type 1.txt ^| find "_$abctitle_"') do (
  3.     set "str1=%%i"
  4. )
  5. for /f "tokens=2 delims==" %%i in ('type 1.txt ^| find "_$cdectitl_"') do (
  6.     set "str2=%%i"
  7. )
  8. echo,%str1%
  9. echo,%str2%
  10. pause
复制代码

作者: 5i365    时间: 2021-11-1 10:07

回复 24# Batcher


    如何在ps下使用cmd取值, 下面的方法, 取不到
cmd /c "for /f "tokens=2 delims==" %%i in ('type 1.txt ^| find "_$abctitle_"') do ( echo%%i)"
作者: 523066680    时间: 2021-11-1 10:37

本帖最后由 523066680 于 2021-11-1 13:10 编辑

'$abctitle' 字面强行保留原样(还是perl)
  1. my $k1 = '$abctitle';
  2. my $k2 = '$cdectitl';
  3. while ( $str =~ /_(?:\Q$k1\E|\Q$k2\E)_[^=]*=(.+)$/gm) { print encode('gbk', $1),"\n" }
复制代码
或者在 $ 前面加斜杠,起码没有把它们从字面上拆开或者从中间插入其他符号
  1. while ( $str =~ /_(?:\$abctitle|\$cdectitl)_[^=]*=(.+)$/gm) { print encode('gbk', $1),"\n" }
复制代码

作者: aloha20200628    时间: 2021-11-1 11:35

test.txt(简中编码):
_$abctitle_大中国=小日本, 美国佬!
_$cdectitl_大中华=小日本, 英国佬!

在powershell命令行运行代码如下:
foreach ($t in type 'test.txt') {$t=($t -replace '.*=');Write-Host $t;}
屏显运行结果:
小日本, 美国佬!
小日本, 英国佬!




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