AdvertCN - 广告中国

 找回密码
 立即注册

QQ登录

只需一步,快速开始

PropellerAds
 谷歌+Bing+TT+MSN官方代理 
⚡️按条S5代理⚡️静态⚡️独享⚡️5G需要代理IP?⚡️Proxysites.ai⚡️指纹浏览器,就用AdsPower
Mediabuy⚡️玩家开户首选【鲁班跨境通-自助充值转账】FB/GG/TT❤️官方免费开户Affiliate 全媒体流量资源⚡️
Taboola/Outbrain /Bing⚡️一级代理开户投流-7*24h❤️人工在线【官方】❤️搜索套利买量投流开户独立站⚡️开户投放
DuoPlus专注打造跨境电商云手机E.PN 虚拟卡BINOM TRACKER 60% OFF!比Adplexity还好用的Spy工具
ADPLEXITY + ADVERTCN7200W全球动态不重复住宅IP代理虚拟信用卡+独立站收款全球虚拟卡, 支持U充值
Facebook 批量上广告尤里改 - FB 稳定投放免费黑五教程(持续更新、欢迎交流)FB 三不限源头 - 自助下户充值转款
各种主页、账单户、BM户(优势)⚡️个人户,bm户不限额,账单户9Proxy ⚡️ $0.04/IP, 无限带宽 IPCola原生住宅IP⚡️$2.1/条双ISP
Google、Bing官方总代  联盟流量开户fb耐用号0.01一个fb账号官方合作商FB资源,账单户,分享户,国内一手
FB企业户BM户账单户源头广告位出租  
查看: 26363|回复: 26

[讨论] 求助从大文本中提取邮件地址

[复制链接]

38

主题

2414

广告币

2632

积分

高级会员

Rank: 4

积分
2632

社区QQ达人

发表于 2017-12-1 00:08:03 | 显示全部楼层 |阅读模式
本人有一个1G大的文本文件,里面是一些乱七八糟的文字,但是有部分邮箱地址 ,我想把这些邮箱地址提取出来 ,有什么好办法吗?试了好几个提取工具,连文本都打不开,打开文本超过5M就没反应了,有更好的办法吗?江湖救急!!谢谢!!!
5 o. R+ u& e4 z+ N5 @9 S0 F2 M9 B
相关帖子
回复

使用道具 举报

23

主题

1240

广告币

2187

积分

高级会员

Rank: 4

积分
2187

社区QQ达人

发表于 2017-12-1 00:14:04 | 显示全部楼层
PHP 一行一行的读取 然后从每一行里面正则表达式去匹配邮箱 应该是可以搞定的
回复 支持 1 反对 0

使用道具 举报

55

主题

105

广告币

647

积分

中级会员

Rank: 3Rank: 3

积分
647

社区QQ达人

发表于 2017-12-1 08:30:59 | 显示全部楼层
1G  分分钟搞定
回复 支持 反对

使用道具 举报

3

主题

38

广告币

58

积分

初级会员

Rank: 2

积分
58

社区QQ达人

发表于 2017-12-1 08:39:37 | 显示全部楼层
[\w!#$%&'*+/=?^_`{|}~-]+(?:\.[\w!#$%&'*+/=?^_`{|}~-]+)*@(?:[\w](?:[\w-]*[\w])?\.)+[\w](?:[\w-]*[\w])?$ `& h7 z# K& |! q% r+ y
这个正则可以匹配,不过具体要用其他工具来实现匹配。

评分

参与人数 2广告币 +7 收起 理由
风儿 + 5 赞一个!
chable + 2 可以结合使用EMEDITOR

查看全部评分

回复 支持 反对

使用道具 举报

2

主题

314

广告币

444

积分

中级会员

Rank: 3Rank: 3

积分
444

社区QQ达人

发表于 2017-12-1 08:50:15 | 显示全部楼层
懂点编程的话用读取字节的IO函数读取加转换处理,3个G大小没问题,再大就用内存映射的方法。
( N; f$ |$ F+ V0 ?0 x# h" n4 ^& a
  _* y: D$ b" d( n. C8 {; \不懂编程的话先将大文本分割成很多个小文件,再用你找到的那些工具处理。
QQ:2696779792
回复 支持 反对

使用道具 举报

59

主题

761

广告币

1988

积分

高级会员

Rank: 4

积分
1988

社区QQ达人

发表于 2017-12-1 09:46:01 | 显示全部楼层
hadoop,3个t也能给你搞了
回复 支持 反对

使用道具 举报

52

主题

749

广告币

1411

积分

高级会员

Rank: 4

积分
1411

社区QQ达人

发表于 2017-12-1 10:31:22 | 显示全部楼层
写个正则匹配。。。。
我是C罗!!!
回复 支持 反对

使用道具 举报

12

主题

1856

广告币

2442

积分

高级会员

Rank: 4

积分
2442

社区QQ达人

发表于 2017-12-1 12:07:47 | 显示全部楼层
各显神通.~~  我就找个漂亮的小妹 让她慢慢处理吧...
回复 支持 反对

使用道具 举报

38

主题

2414

广告币

2632

积分

高级会员

Rank: 4

积分
2632

社区QQ达人

 楼主| 发表于 2017-12-1 12:28:08 来自手机 | 显示全部楼层
大神真多啊!有没有现成的工具推荐一下?自己编程太麻烦了
回复 支持 反对

使用道具 举报

3

主题

38

广告币

58

积分

初级会员

Rank: 2

积分
58

社区QQ达人

发表于 2017-12-1 13:09:44 | 显示全部楼层
http://tool.oschina.net/regex#
2 C; L! o9 o) \- W7 T# ~" u本来想自己写一个python脚本,不过中午折腾rb格式,没折腾出来。$ y/ c' ~* ?8 M6 S3 g: M
目前手动比较方便一点的就是,把内容放到上面这个正则工具里,点击右边的匹配邮箱,然后点击测试匹配。下面邮箱就全部匹配了。. N! m/ y2 M( u- s3 a: R$ i2 A
鼠标移动上去,拉取,选中,复制到其他txt,excel里。搞定。

评分

参与人数 1广告币 +5 收起 理由
风儿 + 5

查看全部评分

回复 支持 反对

使用道具 举报

103

主题

1823

广告币

2703

积分

高级会员

Rank: 4

积分
2703

社区QQ达人

发表于 2017-12-1 13:31:21 | 显示全部楼层
EDITPLUS+正则
回复 支持 反对

使用道具 举报

38

主题

2414

广告币

2632

积分

高级会员

Rank: 4

积分
2632

社区QQ达人

 楼主| 发表于 2017-12-1 17:15:30 | 显示全部楼层
大神们 是1G的文本文件 不可能手工粘贴上去。更不是一个文本编辑器能处理的
回复 支持 反对

使用道具 举报

26

主题

1059

广告币

2682

积分

高级会员

Rank: 4

积分
2682
发表于 2017-12-3 21:25:04 | 显示全部楼层
EmEditor(文本编辑器)。官方说的处理248G的文件也不在话下。然后用正则表达式把非邮箱的字符替换为空白,把邮箱留下就可以了。

点评

大神 我用 正则[-0-9a-zA-Z.+_]+@[-0-9a-zA-Z.+_]+\.[a-zA-Z]{2,4} 绿色高亮了所有EMAIL,问题是我如何给他取反呢?把不是emial的全部替换为空格呢?  详情 回复 发表于 2017-12-4 11:44
大神能给个正则表达式替换的例子吗?  详情 回复 发表于 2017-12-3 23:01

评分

参与人数 1广告币 +2 收起 理由
affempire + 2 NB!

查看全部评分

回复 支持 反对

使用道具 举报

38

主题

2414

广告币

2632

积分

高级会员

Rank: 4

积分
2632

社区QQ达人

 楼主| 发表于 2017-12-3 23:01:50 | 显示全部楼层
alibaba 发表于 2017-12-3 21:25( O0 |' D: X7 x7 j1 ~
EmEditor(文本编辑器)。官方说的处理248G的文件也不在话下。然后用正则表达式把非邮箱的字符替换为空白, ...

' z& g: v* U3 s  W  |5 ?/ b大神能给个正则表达式替换的例子吗?
回复 支持 反对

使用道具 举报

19

主题

290

广告币

532

积分

中级会员

Rank: 3Rank: 3

积分
532

社区QQ达人

发表于 2017-12-4 00:39:19 | 显示全部楼层
本帖最后由 bjzhush 于 2017-12-4 00:45 编辑 ; A% Z; Q! h8 d  C+ h& j

: T. ?! i$ U% B+ H花了几分钟帮你写了下 : m1 P( x4 g. U# }  X- i
例如源文件为这个txt
8 a, a( Y) e, o8 h( ?$ Q' [➜  ~ cat x.txt
& U- f2 ?5 S7 s: Ghitest3 r! x5 ^9 I0 S
[email protected]
2 E& N" L& e2 S, Y5 ?* \7 F# ghi  [email protected] test
# D- m  u6 Z. q! }* V4 s[email protected]  [email protected]9 }2 y( K/ X; b, s7 s: @
执行后,得到result.txt( p* d. y7 `. m! k3 R; x6 X+ m
➜  ~ cat result.txt
/ T/ R! [0 A* T8 w/ G3 R% W/ n; C[email protected]
2 m/ x# s9 |7 e[email protected]
1 J% Z) h3 }% f: k7 a1 p1 H[email protected]& h% x/ \1 F3 R6 F( w9 `
[email protected]
+ Q/ }, |  k5 _) G* @
  I. O+ }, x1 {4 m& `代码如下:
' R" }1 o/ K* S! y
  1. <?php
    3 o' Q' z+ M# c+ g! ?" n. A
  2. $file = 'x.txt';
    # S  w/ J+ \7 J7 C2 P
  3. $fp = fopen($file, 'r');9 J; ?2 v/ |# ]5 B! j8 l8 X
  4. if (!$fp) {
    & X7 R/ k2 c6 S! K8 G- p1 A% ~3 I+ L
  5.     exit('failed to open'.$file);3 q& W" e4 o% O3 |3 t; G6 U- f! m
  6. }) O& J# r8 ?) a  m2 D& ^4 L
  7. $lineNumber = 0;
    : M) P" q3 ?4 P' \+ K* {( u
  8. while($line = fgets($fp)) {6 s! \, |: D" }* M- q
  9.     $lineNumber++;7 U' P& m$ `3 E, \
  10.     $pattern = '/[a-z0-9_\-\+]+@[a-z0-9\-]+\.([a-z]{2,4})(?:\.[a-z]{2})?/i';
    1 T/ L0 ]: N; l: s
  11.     preg_match_all($pattern, $line, $matches);
    8 Y9 R6 F, C3 |! h' r
  12.     if (!empty($matches[0])) {1 i, J1 p9 H5 y, I7 M9 F& G
  13.         foreach ($matches[0] as $mail) {& j+ F" i& F6 L4 I1 W
  14.             echo $mail.' found from line '.$lineNumber.PHP_EOL;
    5 _& l* A7 `. `+ `0 }
  15.             file_put_contents('result.txt', $mail.PHP_EOL, FILE_APPEND);
    6 |. P; n1 y1 d' P- L4 F2 Q4 C
  16.         }
    + p, R$ T2 J% f  o
  17.     }. _5 x" c+ d  f7 r- ^* L( H
  18. }
    ' Z- f# d) q) [5 t
  19. echo "All Done";/ z6 ^" b5 d. D6 C* f$ q
复制代码
功能:支持提取一行多个email地址,结果全部保存到result.txt ,没有做去重# C4 ~$ X% w5 |  j/ L
使用:代码里面的源文件是x.txt ,可以换成你自己的文件名,php保存为getMail.php  然后  php getMail.php 结果保存在result.txt里面

评分

参与人数 2广告币 +7 收起 理由
leeker + 5 乐于助人
iyahoo + 2 很给力!

查看全部评分

回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关于我们|联系我们|DMCA|广告服务|小黑屋|手机版|Archiver|Github|网站地图|AdvertCN

GMT+8, 2025-2-23 01:34 , Processed in 0.067293 second(s), 20 queries , Gzip On, MemCache On.

Copyright © 2001-2023, AdvertCN

Proudly Operating in Hong Kong.

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