掌上百科 - PDAWIKI

 找回密码
 免费注册

QQ登录

只需一步,快速开始

查看: 4948|回复: 148

[资料] MDX词组提取 - 从正则进阶到头发护理

    [复制链接]
  • TA的每日心情
    慵懒
    2018-8-25 12:29
  • 签到天数: 91 天

    [LV.6]常住居民II

    发表于 2018-5-3 00:01:37 | 显示全部楼层 |阅读模式
    本帖最后由 garypang 于 2018-5-8 18:56 编辑 " L) y( }; f+ y( \8 i* N; a* E
    2 |6 o- ~; v8 |' Z6 v4 J0 b! M
    阅读本帖前建议对正则表达式有一定的了解,本帖不做基础知识普及,只讲解关键点和思路
    9 [8 u" E# A4 _) Z7 z  Q  a( w5 Y
    6 v& k/ t0 p) p2 o7 J% m- |在我出了两个词组提取资源帖后,不少小伙伴都留言表示希望我出教程帖,也有希望我提取某某词典的词组,秉着授之于鱼不如授之以渔,造福论坛和广大网友的想法,分享下我提取朗文5++词组的全过程,只要跟着我一步一步来,哪怕不懂代码的小白,也能提取出朗文5++,但是要扩展到自己提取其他词典,则需要看懂各个步骤,并举一反三啦.0 q- @3 u& R3 ]) H, h) m) v1 q9 e
    - T9 c  y. c* A5 ^
    所用工具:9 G1 e% d, x, [  E/ a2 r" @
    文本编辑器 notepad++  https://notepad-plus-plus.org/download/ (其他编辑器无法保证本帖提供的正则正常运行)
    4 T! D, E' |5 Q) m, y- C& o  X" m) {6 }; v
    tidy-html5  https://github.com/htacg/tidy-html5
    1 \9 G$ h# P* s; Q2 ]已编译好版本,直接下载! \# H- H4 d7 E9 F3 b
    游客,如果您要查看本帖隐藏内容请回复
    + Y) B% D. K: x4 B$ `

    - [% m7 I* Y* B& w0 vmdx解压软件MdxExport   mdx打包软件 MdxBuilder   论坛有提供下载,
    ( |& E5 J0 _0 c5 h: m- s  j8 F2 T, _/ z+ z. y" g9 H3 U+ N% {
    具体步骤0 e6 w! ~8 k3 K' }# a) N

    . I6 ~8 C1 k- _( i! o5 N& [0 ~4 p第一步 使用MdxExport 将mdx文件解压成txt文本文件
    ; a" |8 ?! u# x9 `7 J% y2 J7 m. ^/ ^
    第二步" `- C: s' J( f' K8 Z5 f
    用notepad++打开解压后的txt文件,ctrl+H打开替换窗口% n  K& |3 H3 F; x: g* r
    # L, f( [( j& t  ?3 P# C3 a
    替换目标:
    1. .*?(<a name="\w+?"></a><span class="(newline ){0,1}Sense( LDOCEVERSION_new){0,1}" id="\w+?">(<span class="LDOCE5pp_sensefold){0,1}.{0,400}?<span class="REFHWD merge_sense.*?)<!-- End of DIV dictionary-->.*?
      ; e% H' \: q4 E- L$ l% U/ c+ T
    复制代码
    % S5 K3 o; n+ ?' Y+ s
    + v7 w; o6 g* m& z. A! {
    替换为:
    1. \1\r\n
    复制代码
    查找模式:正则表达式   勾选匹配新行  保存替换后的文件为hb.txt
    0 ?8 H& y- X7 H. X4 Z0 W
    8 }0 g# l' g$ E: H/ ^7 Q7 Z讲解:+ T$ P8 ~2 m- S" H" Q! y

    5 _( P! `, g" v$ x+ x: H观察朗文5++词组部分的数据结构
    & }& @: y6 p: `0 D
    6 B/ y( B5 d' t( n
    0 J- A4 F3 _9 k1 z$ P- F& e, z) g) X6 R# y: ?  M9 C. N
    词组部分起始位置标签是类似<span class="newline Sense " id="go__phr__1">,用正则很容易就匹配到,但是末尾闭合标签全是</span> 无法匹配,暂且先匹配至词组所处单词的释义的最末尾 即<!-- End of DIV dictionary-->,做为第一步的筛选,可以去掉很大一部分无用的内容) S$ T6 r" `3 x7 I/ x% q

    ) W& j  C1 _/ @替换后结果是这样的
    * J  Z5 `4 |! a% W9 i/ @0 S* }' i, }7 h6 @

    ) z  t6 X% \3 w' ?2 d9 _! n, t& }第三步
    . Q) D, K+ e* i6 j打开 hb.txt7 m! b( v- P9 V, q( D
    替换目标:
    1. <span( class="(newline ){0,1}Sense( LDOCEVERSION_new){0,1}" id="\w+?">(<span class="LDOCE5pp_sensefold){0,1}.{0,400}?<)span( class="REFHWD merge_sense)2 W; c, ?* m+ z8 c
    复制代码

    9 J+ c* Y" Y- }: n替换为:
    1. <jia\1hwd\5
    复制代码
      查找模式:正则表达式  4 G$ g2 D/ K5 c) C' L
    0 g( @3 `" @  r* H, T5 X
    讲解:7 O( m$ F- i* s
    这一步的目的是将词组的起始标签比如<span class="newline Sense " id="go__phr__1">改为自定义标签<jia class="newline Sense " id="go__phr__1">,将词组名的起始标签 <span class="REFHWD merge_sense>改为<hwd class="REFHWD merge_sense> 为下一步格式化html做准备& j! S, q5 j& j, B3 T9 L. Z# O) v

    1 r* P  ~  z+ H7 I/ D) O" s, a) d第四步- l4 _( C5 [& Z  p* m. V
    游客,如果您要查看本帖隐藏内容请回复

      F- i+ h" x  d7 ^) ~; _- e等待过程中的窗口
    / ^6 ]+ F9 Y" l( s; }
    - e! b. S& h; p4 h9 ^+ V
    * F/ e$ k0 b) K) `; s7 W9 W讲解+ y. a3 w2 W/ E
    tidy是个大杀器,能将html格式化的同时自动修复html里的错误,比如我们前面改的自定义标签<jia>和<hwd>,tidy会自动配对这两个标签的闭合标签,发现是</span>而非</jia></hwd>,则会自动将闭合标签改为独一无二的</jia>和</hwd>
    ; S; H+ `  B  d" o$ c4 Q: p: l! L这样我们就能轻松通过正则匹配到每个词组的结尾标签位置以及词组名结尾标签位置0 t" q9 f  ]% D, o& p; g( Y
    # ~: W+ `% O, H0 a
    第五步5 j, T; i5 a# H, M
    打开 output.txt& }* w, K' y& S; l  t9 p
    替换目标:
    1. .*?(<a name="\w+?"></a>\r\n\s+?<jia class="(newline ){0,1}Sense( LDOCEVERSION_new){0,1}" id="(\w+?)">.+?<hwd class="REFHWD merge_sense[\w\s]*?">(.{1,280}?)</hwd>.*?</jia>).*?7 \; A- [& p7 H5 U7 i
    复制代码
    ; h) i' r% k/ Q: y3 v
    替换为:
    1. \5\r\n<link href="LM5style_vanilla.css" rel="stylesheet" type="text/css" /><link href="LM5style.css" rel="stylesheet" type="text/css" /><link href="LM5style_switch.css" rel="stylesheet" type="text/css" /><link href="LM5style_show.css" rel="stylesheet" type="text/css" /><script src="jquery-3.2.1.min.js" charset="utf-8" type="text/javascript"></script><script src="LM5Switch.js" charset="utf-8" type="text/javascript"></script><span class="lm5ppbody"><div class="entry_content"><div class="dictionary"><span class="dictentry"><a name="\4__a"></a><span class="ldoceEntry Entry" id="\4"><span class="frequent Head"><span class="HWD">\5</span></span>\1</span></span></div></div></span>\r\n</>\r\n; `$ {6 [  B% f: C0 h4 [
    复制代码
    查找模式:正则表达式   勾选匹配新行" n7 |+ Y, [0 S0 b
    8 R: \+ D+ z0 Z' y8 _" I6 K6 y2 p9 t
    讲解1 Z* b, b2 t  h, A  N
    既然我们能确定所有词组的起始和结束位置,以及词组名的起始和结束位置,那就可以彻底干掉所有没用的内容,只留下有用的词组相关的内容,并将其格式化为mdx要求的格式
    / O) R1 Y' W5 Y* K' p% g" E$ q9 `$ B- P
    替换后效果
    / c" k/ ^" J8 A" a/ H5 c7 `" f/ d- k' K9 v, k

    5 X+ z" n0 |& ^9 g' w# ^& G% |到这一步,一部词典的词组提取已经完成了! {9 c# d7 C3 s) y

      [0 H& u) N# F/ ~接下来步骤是针对朗文5++词组的调整和优化,不同词典可能不同.
    2 O3 t4 M! S6 ?
    ) d, q+ B  ]* {( F4 G第一步:
    ! X' n3 g/ b% Q上一步完成后,提取出来的词组名有些是这样的3 h+ V# H0 Q6 R$ p5 k' W5 o
    , f6 {$ q1 N+ l& }0 y# X

    4 ~2 e) U0 }- H需要改为abide by something   
    7 u* e; R4 d0 n4 k; ?+ ]0 ?$ |
    9 x6 y1 I; a3 f! [
    1. (^</>\r\n.+)\r\n\s*?<span class="OBJECT">(.+?)</span>4 h! X- ^4 l/ D3 i. N; a
    复制代码
    1. \1 \2
      ; T6 S, v) S. a- J
    复制代码
    查找模式:正则表达式   需要替换两次,因为有些是两个<span class="OBJECT">(.+?)</span>  比如 take somebody up on something- r( d8 D- g& K2 P8 N# u

    8 u* C0 C) c7 a; v1 K; M8 G第二步& ^$ R7 I% ^3 G
    去掉词组名里的双空格 三空格" C# `/ j2 C; d2 D8 G% [& ^
    替换目标:
    1. ^(.+?)(  |   )(.+?)\r\n<link
    复制代码

    1 `$ C" ~3 I# w! l替换为
    1. \1 \3\r\n<link
    复制代码
    查找模式:正则表达式    需要替换两次 因为有些词组名中多空格不止出现一次2 n* \, ~' \- L. ?; F
    / I/ B2 c- w: `' h: w4 p
    第三步
    5 j8 N) k8 G# t' t9 _+ M& u: g愿词典词组中 比如somebody's 使用的是 ’ 而非标准的单引号 ' 作为上标 需要改过来,否则会造成一些词组查不到
    . i9 [8 @' ~" L7 R. ^) ^替换目标:
    复制代码
    # p# ^$ T" y+ b% o+ Y
    替换为:
    1. '
    复制代码
    查找模式:普通
    " N/ F( z1 ], j9 f7 x' ~5 \4 I( A: T* X9 Y1 j9 W
    第四步
    3 V- f8 q; j, X6 v去除词组前面的数字序号
      x8 J" T: `& t- I! G替换目标
    1. \r\n\s*?<span class="sensenum span"( newline="yes"){0,1}>[0-9]+</span>
    复制代码

    7 F2 C) W1 C* J3 P. t. E- l9 r6 f替换为 空
    ! M7 G$ R4 j! s* G  s1 `! d+ t  Q  T) c: D  s2 {& B* u
    还有进阶的针对查词的灵活性优化,合并原词典后的去重,这些就不说了,每部词典不同,没有通用性,
    6 ]( s, @7 R) y& w9 `) k: X: H  x8 n* x) i2 m& K
    最后将完成后的文件内容复制到原mdx解压的txt中顶部, 用MdxBuilder   打包即可
    5 N! x* f  }8 O! n: U
    . [7 |: Z% N6 f  x+ N/ g  W& V7 r只要严格按照我的步骤来,就一定可以完成提取,我是一遍码帖,一遍操作完成了一次提取的.
    8 @) t8 @$ A% n, m# Q) o8 y5 T% r7 B1 v+ L
    希望大家踊跃行动起来,提取出自己的词组词典,造福大家!
    . Z& m$ A, g, X2 K. J  I1 c! B. Q  \( x' d4 i9 h) b
    有问题请私信,正则,mdx等的基础知识普及不回哦.
    - z, H/ P' {! l6 @* z* X0 J4 A: Q  p6 B; ]/ H" C4 t/ m
    3 S0 l. g$ g) n7 r

    % r3 o7 m0 O8 {( j$ @' ~7 {
    7 [( w# a8 h% K5 R( y1 h- r) c3 \

    本帖子中包含更多资源

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

    x

    评分

    8

    查看全部评分

    本帖被以下淘专辑推荐:

    • · 工具|主题: 51, 订阅: 20
  • TA的每日心情
    奋斗
    2019-4-14 02:12
  • 签到天数: 93 天

    [LV.6]常住居民II

    发表于 2019-1-8 17:21:09 | 显示全部楼层
    编译了一个Mac版tidy html
      E# U4 [0 l( p* W3 l不知道可以用不… 反正按官方步骤编译的。
    ( Z0 M( \, k9 W% B) n3 iMac用户有需要的时候 可以试试。* J! y: O% ~" c

    本帖子中包含更多资源

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

    x

    评分

    1

    查看全部评分

  • TA的每日心情
    开心
    2019-2-14 21:07
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2019-3-11 18:57:37 | 显示全部楼层
    把mdx导进sqlite3里面(网上能找到一个readmdict.py,稍微修改一下就能干这个),然后逐条处理,会不会比直接处理一个大txt要省劲一点儿?
    / V1 D8 {' H6 C* k- R. B
    6 q+ J: e% H# z+ u# A& g7 f/ I我是用node.js来做正则处理的。当然用python也一样。
  • TA的每日心情
    开心
    2018-5-27 05:26
  • 签到天数: 55 天

    [LV.5]常住居民I

    发表于 2018-5-4 17:02:13 | 显示全部楼层
    本帖最后由 nidetou 于 2018-5-4 17:13 编辑
    2 {7 m* ~* j7 M* S' s6 O" l2 z/ \& d1 y
    链接:https://pan.baidu.com/s/1LbaCNOIHVV-tND9Dg48QgQ 密码:omwb& P5 j9 r) H. C, `$ b5 L4 N
    - Z9 F; u2 Y9 t
    我提取Laad3词典例句音频(coca5000),按字母顺序分割为51个文件.最头痛的是每个单词下的例句没有排序。所以应按照theaurus, phrase,collocation, spoken和意项五个部分分别提取(如有可能把usage也单独提取),即使顺序不对,也没有什么大碍。
  • TA的每日心情
    开心
    2018-5-27 05:26
  • 签到天数: 55 天

    [LV.5]常住居民I

    发表于 2018-5-4 16:08:09 | 显示全部楼层
    本帖最后由 nidetou 于 2018-5-4 17:14 编辑 ) ?1 G6 q4 y. M: a) ]0 e1 D

    / T4 c5 Z' `7 N这个一定要收藏,我想把coca5000从LAAD3提取音频例句,让大家听。由于不熟悉计算机语言,找到anki一款插件提取mdd文件中的音频,我是一个一个手工提取(大家别笑我,人笨没办法),合并文件有50多小时,没有放在出来的原因是例句排序很很麻烦。我感觉应分五个部分提取,theaurus, phrase,collocation, spoken和意项(如有可能usage也单独提取)。学外语大量听优先。如果有可能再把coca5000-10000提取,这样可建立输入词汇在大脑里形成bank.
  • TA的每日心情
    开心
    2020-5-23 22:47
  • 签到天数: 128 天

    [LV.7]常住居民III

    发表于 2018-5-3 00:44:36 | 显示全部楼层
    非常好的东西,这么晚了还在码,辛苦了。明天我也要好好学学怎么替换……
    8 V2 \% Y. }4 }! }( w7 ?. [6 X比较好奇的是,为什么有些词典,例如简明必应 https://www.pdawiki.com/forum/fo ... hread&tid=20726 这份词典里
    % A7 z3 ]+ t' u( E+ f& b一些比如say等基础词汇,会出现前缀,后缀的,-等符号,导致如果将该词典作为首词典查询单词的时候,由于搜索机制的问题,输入say,会直接被导向-say之类的,然后……一个say搜出很多个同样的解释。* Q7 w! `' D5 b( y
    不知道制作这样带有符号的同一个单词,是批量生成过程中产生的问题,还是为了作为词组存在留下的。- X0 X5 j2 [4 l4 x* n& j
    研究好以后,看看能不能正则把这部分切了。
  • TA的每日心情
    开心
    2018-6-18 01:07
  • 签到天数: 102 天

    [LV.6]常住居民II

    发表于 2018-5-3 00:47:22 | 显示全部楼层
    QQending2 发表于 2018-5-3 00:44
    6 p5 `; |* d* ^: N非常好的东西,这么晚了还在码,辛苦了。明天我也要好好学学怎么替换……
    / W* r& s5 F+ \* I: w) j比较好奇的是,为什么有些词典, ...
    出现前缀,后缀的,-等符号
    词典中本来有这些词条,不奇怪
  • TA的每日心情
    开心
    2020-4-2 14:11
  • 签到天数: 464 天

    [LV.9]以坛为家II

    发表于 2018-5-3 14:23:25 | 显示全部楼层
    非常感谢楼主的分享!!!
  • TA的每日心情

    2020-9-7 05:50
  • 签到天数: 178 天

    [LV.7]常住居民III

    发表于 2018-5-3 19:32:29 | 显示全部楼层
    不管东西咋样 还是先谢谢了
    : z1 B! ~- L# }; c* p" F
  • TA的每日心情
    擦汗
    4 小时前
  • 签到天数: 1050 天

    [LV.10]以坛为家III

    发表于 2018-5-3 20:50:11 | 显示全部楼层
    很喜欢关于词典技术的讨论
  • TA的每日心情
    开心
    2018-4-10 07:58
  • 签到天数: 60 天

    [LV.6]常住居民II

    发表于 2018-5-3 23:49:13 | 显示全部楼层
    给楼主点赞,这份工作需要一些创造力
  • TA的每日心情
    开心
    昨天 00:02
  • 签到天数: 1002 天

    [LV.10]以坛为家III

    发表于 2018-5-4 00:34:27 | 显示全部楼层
    Thanks for sharing...
  • TA的每日心情

    2018-6-16 18:13
  • 签到天数: 158 天

    [LV.7]常住居民III

    发表于 2018-5-4 11:40:55 | 显示全部楼层
    千呼万唤始出来啊
  • TA的每日心情
    慵懒
    2018-9-28 00:22
  • 签到天数: 273 天

    [LV.8]以坛为家I

    发表于 2018-5-4 12:11:30 | 显示全部楼层
    还是要对正则熟悉。
  • TA的每日心情
    开心
    2018-5-27 05:26
  • 签到天数: 55 天

    [LV.5]常住居民I

    发表于 2018-5-4 16:11:01 | 显示全部楼层
    本帖最后由 nidetou 于 2018-5-4 16:34 编辑 & J* J% A& Q' ?% e6 Y6 g

    : m! |, R2 {7 d% P* _8 z. l朗文现代不好的原因是例句英美音混杂。
  • TA的每日心情
    开心
    3 小时前
  • 签到天数: 757 天

    [LV.10]以坛为家III

    发表于 2018-5-4 22:55:18 | 显示全部楼层
    谢谢,下来看看
  • TA的每日心情
    开心
    2019-10-25 14:29
  • 签到天数: 32 天

    [LV.5]常住居民I

    发表于 2018-6-7 22:44:39 | 显示全部楼层
    感谢楼主的分享!学习下。
  • TA的每日心情
    开心
    5 小时前
  • 签到天数: 1043 天

    [LV.10]以坛为家III

    发表于 2018-6-7 23:15:15 | 显示全部楼层
    谢谢楼主的介绍,很想学习制作,先从基础开始

    该用户从未签到

    发表于 2018-6-14 17:35:07 | 显示全部楼层
    感谢楼主分享制作经验,学习了!
  • TA的每日心情
    擦汗
    2020-2-7 12:22
  • 签到天数: 44 天

    [LV.5]常住居民I

    发表于 2018-6-15 17:20:23 | 显示全部楼层
    好贴!讲的很详细!可惜我看到的太晚了,浪费了好多时间
  • TA的每日心情
    开心
    2018-6-18 09:03
  • 签到天数: 110 天

    [LV.6]常住居民II

    发表于 2018-6-15 18:17:14 | 显示全部楼层
    学习了。虽然会一丁点的正则,但一直没有太怎么敢用在这种大型处理上。
  • TA的每日心情
    开心
    2019-7-11 11:21
  • 签到天数: 313 天

    [LV.8]以坛为家I

    发表于 2018-6-15 22:24:34 | 显示全部楼层
    非常感谢garypang精心整理,无私分享,授人以渔!
  • TA的每日心情

    2018-6-15 14:54
  • 签到天数: 3 天

    [LV.2]偶尔看看I

    发表于 2018-6-16 18:47:15 | 显示全部楼层
    过来学习一下
  • TA的每日心情
    慵懒
    昨天 07:16
  • 签到天数: 922 天

    [LV.10]以坛为家III

    发表于 2018-6-16 19:24:52 | 显示全部楼层
    这个要好好学习下& ]9 N/ t8 [9 r/ g
    正则看不懂,哎。。。。。。。。。。
  • TA的每日心情
    开心
    2018-6-20 16:04
  • 签到天数: 1 天

    [LV.1]初来乍到

    发表于 2018-6-20 19:56:03 | 显示全部楼层
    看看啊。这个应该是非常好的。XUEXIB LA
  • TA的每日心情
    奋斗
    2020-7-12 05:59
  • 签到天数: 97 天

    [LV.6]常住居民II

    发表于 2018-6-25 16:42:23 | 显示全部楼层
    谢谢garypang 实在是太感谢了 谢谢 对我帮助很大 可以自己diy了
    您需要登录后才可以回帖 登录 | 免费注册

    本版积分规则

    顶部qrcode底部
    关注掌上百科官方微信公众号送论坛充值码
    关注掌上百科官方微信公众号
    关注微信公众号 pdawiki,获取邀请码,看文抢积分,抽奖得浮云! Follow our Wechat official account "pdawiki", get invitation codes, and play the lottery to earn points (积分)!

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

    GMT+8, 2020-10-24 10:53 , Processed in 0.073300 second(s), 17 queries , MemCache On.

    Powered by Discuz! X3.4

    Copyright © 2001-2020, Tencent Cloud.

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