[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[问题求助] PowerShell如何用正则取=后面的字符?

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

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

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

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

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

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

TOP

本帖最后由 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" }
复制代码

TOP

回复 24# Batcher


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

TOP

回复 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
复制代码
1

评分人数

我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

回复 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
复制代码
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

回复 21# 523066680


    牛, 如果能在Powershell中用正则直接取就好了

TOP

串个频道

本帖最后由 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. 小日本, 英国佬!
复制代码

TOP

回复 18# idwma


    用这种办法 我需要先把_$abctitle_ 先改成 _[$](abctitle)_  这样才可以

TOP

回复 18# idwma


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

感觉可能还有更简单的办法

TOP

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

回复 17# 5i365

测了是可以的呀

TOP

回复 16# idwma


    输出值是:

_$abctitle_澶т腑鍥?灏忔棩鏈? 缇庡浗浣?
_$cdectitl_澶т腑鍗?灏忔棩鏈? 鑻卞浗浣?

TOP

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

评分人数

TOP

回复 14# idwma


    还是不行, 转义 符 用 ` 也不行

TOP

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

TOP

返回列表