掌上百科 - PDAWIKI

 找回密码
 免费注册

QQ登录

只需一步,快速开始

查看: 811|回复: 9

[求助] 【已解决】如何提取正则匹配结果?

[复制链接]

该用户从未签到

发表于 2016-1-11 22:02:46 | 显示全部楼层 |阅读模式
本帖最后由 qiuhao1112 于 2016-1-11 22:28 编辑 5 ]% G1 m1 O6 Q8 H! m- V

  [/ O$ @1 E( m& G最近使用notepad++和ultraedit一直有件让我非常郁闷的事,就是使用正则表达式匹配出了所需要的一堆字符串后却不知道怎么把这些字符串提取出来。。。折腾了好久,网上说ultraedit有个什么复制查找结果的功能按钮,可我愣是没找到,也不知道他们说的是哪个版本,这个问题简直要命,请高手帮我指点一下。。谢谢: p* i7 d8 z2 m6 _% b

! d4 D# {- u  _- O另外曲线救国的方式我试过,太繁琐,太折腾,还容易出错,所以还是给个直接点的办法好了,仅提取匹配到的结果就行,谢谢了。
8 @5 O9 w' W3 J' Y( Q

本帖被以下淘专辑推荐:

该用户从未签到

发表于 2016-1-11 22:14:12 | 显示全部楼层

9 R; j" Y0 G& W0 i6 Y7 d额, 我还用着 UltraEdit 19。
2 P/ z0 b! Y7 C2 w6 I( u* \: E$ t- d查找时,注意勾选“列出包含字符串的行”,按下 Enter (必须这样,至少我这个版本没有按钮啥的),就出现“含有查找字符串的行”,右键“复制到剪贴板”,就把那框里所有“含有查找字符串的行”都复制到剪贴板里了。6 X) J  c/ N  T+ h; C3 r% q: I
这里只是把“含有查找字符串的行”而不是“查找字符串”复制到剪贴板,可以先行把查找字符串前后都替换成换行,这样查找字符串就单独一行了,复制得到的结果就是查找到的字符串了。" N: j$ t' G/ V3 y  m
可能有更简单直接的工具和办法,暂不研究了。
& E  n5 a/ }& \- v8 D! s% O# O: g6 p$ [3 Q! z
: W; J4 B0 {( _" Z" B  K6 b
; @6 G/ h; ~7 p1 y3 K# v# p9 X9 M. ~

  e4 `6 D: f' }' G8 c1 [
; b; I/ f. J& A7 {% r  b* W
! I$ _# w2 q" d- A& O+ w! q$ _9 A% d. q4 B. ^% m# U

该用户从未签到

发表于 2016-1-11 22:20:27 | 显示全部楼层
把匹配出来的内容分割成新行,标记这些新行,复制也好,截切也罢,都随你怎么操作了

该用户从未签到

 楼主| 发表于 2016-1-11 22:27:16 | 显示全部楼层
Oeasy 发表于 2016-1-11 22:14
- p3 [0 f6 r8 u6 K额, 我还用着 UltraEdit 19。
1 C" M6 s# ]+ Y查找时,注意勾选“列出包含字符串的行”,按下 Enter (必须这样,至少 ...
' D/ b. u/ f2 A
感谢O大,这个方式我以前还真没想到过,很好的办法,再次感谢Oeasy解答的这么详细,图文并茂。

该用户从未签到

 楼主| 发表于 2016-1-11 22:28:21 | 显示全部楼层
onlyXXenglish 发表于 2016-1-11 22:20  o/ a5 Z' w& |. u. _2 j( l
把匹配出来的内容分割成新行,标记这些新行,复制也好,截切也罢,都随你怎么操作了

0 k& w+ N, a  u谢谢onlyXXenglish,问题解决了

该用户从未签到

发表于 2016-1-12 01:54:54 | 显示全部楼层
EmEditor的话,查找之后,可以直接复制、剪切全部的。
, `2 F. B: s: o3 m9 f, Y% \当然,这个可能不理想,因为你的查找结果未必是一个完整的行。复制、剪切之后可能多个结果堆在一起。8 r5 q: A( H; F5 a  G/ E
所以,我的方法就是每个匹配项都用一行显示,也就是在开头和结尾都\n处理。2 J9 b+ X) m3 R
同时在每个匹配项的前面加一个字符,如★
) |- F, w. r& |) c- X1 a# f为什么?% c' f) W4 N, m1 M+ P& O! Y
因为EmEditor可以给每行排序。这样一来,行首为★的就排列到了一起,而这些就是你想要的结果。
; n) X" N3 Z/ ?- d+ W再将其他不要的(非★开头)的删除即可。
4 c4 ]: Q4 p' g* e$ @) [$ ^  D当然,你行首不加★,分行处理后直接复制、剪切也行。' [6 {; ~+ m. @1 L
只不过个人经验,如果CPU不行,有些大文件的复制、剪切很有些慢。& J3 v; ^" F' P4 {4 F) r, M
4 @+ |& v. @0 q  y5 p
其他文本工具,本人没有用过,想来也差不多。

该用户从未签到

 楼主| 发表于 2016-1-12 21:44:01 来自手机 | 显示全部楼层
LYX1692 发表于 2016-1-12 01:54
% t% x! d# b, y# YEmEditor的话,查找之后,可以直接复制、剪切全部的。0 U' t& W2 M  I6 u! r2 G- {
当然,这个可能不理想,因为你的查找结果未必是一个 ...

9 |4 V# o* U! v: g9 Y- s( x% x提取成功了  谢谢你的解答!

该用户从未签到

发表于 2016-1-13 09:02:48 | 显示全部楼层
本帖最后由 sky66 于 2016-1-13 09:09 编辑
6 S8 D% J! ^5 r% r3 m2 m, C6 \" ?; |  d, c7 n( Y
看来楼主也可以用emeditor的话, 我提供一下我的方式, ' r% I1 T% P, K" B7 K# t
因为常做, 昨天也在用, 我觉得还蛮方便的
2 l, m, w/ ~+ H- v: n  q6 c
' Z6 K3 ~) I# g# J2 @, dStep11 M0 v+ Q& O' }6 p' ^
用正则查找, 前后要用 ( ), 然后按”全部提取
: K$ W: O" r9 Z
, R( Q2 J: N* |* @/ DStep2. i' d' a7 Q3 w; K& M0 I& X2 b' p7 Y
全部提取”后会在新的标签, 这时”替换全部”, 替换为 \n\1\n6 E" q7 W* j0 y, j# i- N1 _

0 m2 s5 i( R6 |8 }7 `Step3
# _2 u* t8 _  Y) E再查找一次, 然后再按一次”全部提取
* @* U* J. E* c6 v* q
' D3 H0 F3 g& o  \7 D) wStep4
8 M8 F4 I* R/ U$ H0 Z又会产生一个新标签, 这个标签就是所需的正则匹配结果.$ a2 s  a/ o! [" j

+ A# G) E- i- a1 @. [; |: y
  y) K% n6 _6 d% ]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?免费注册

x
  • TA的每日心情

    2019-9-20 08:37
  • 签到天数: 214 天

    [LV.7]常住居民III

    发表于 2017-5-9 09:24:52 | 显示全部楼层
    其实 装个Perl 然后抽取应该比较简单~~
  • TA的每日心情
    无聊
    2021-9-17 23:16
  • 签到天数: 341 天

    [LV.8]以坛为家I

    发表于 2017-5-9 17:00:33 | 显示全部楼层
    Vim+Grep简直是神器
    您需要登录后才可以回帖 登录 | 免费注册

    本版积分规则

    小黑屋|手机版|Archiver|PDAWIKI |网站地图

    GMT+8, 2024-5-7 03:14 , Processed in 0.050627 second(s), 9 queries , MemCache On.

    Powered by Discuz! X3.4

    Copyright © 2001-2023, Tencent Cloud.

    快速回复 返回顶部 返回列表