掌上百科 - PDAWIKI

 找回密码
 免费注册

QQ登录

只需一步,快速开始

查看: 21632|回复: 638

[工具] Mdict Editor Tool v2.0.35 -- 多功能个性化词典制作工具

[复制链接]

该用户从未签到

发表于 2016-11-9 19:41:30 | 显示全部楼层 |阅读模式
本帖最后由 spoiltbrat 于 2017-3-27 23:00 编辑 & h: E9 F/ t/ H' p2 n3 W# k
3 K* h& q2 F" M- c# ?
Mdict Editor Tool v2.0.35  -- 多功能个性化词典制作工具( ^; s) p, b: E
; k2 n, p* Y. f$ e: s$ B

5 L. s# S9 h9 b2 {; Z- t5 I# x5 N& Y6 r9 F$ w. d5 }
2017.03.27:' }! U: l$ C$ l- a
发现bug,修正更新。
) w5 _" r6 m- R$ V* `
+ {9 X3 C4 y4 d2017.03.15:
! z* S- H% S# e7 I9 ~$ ~6 s新增提取功能,按HTML标签提取,速度虽然比不上正则,但简单易用,适合没有编程基础的同学,提取更方便。
6 Y! N/ ^0 A" |. F; V正则虽强大,速度快,但处理HTML多层嵌套标签就显得力不从心了。
- C8 `6 U  |3 j4 P* Z; o6 F此功能依赖第三方库lxml,软件打包后体积也略大了一点。
# O6 a% N! d# ^! H' Z
- D2 }! b0 J5 T2 ~; B$ y- z% n4 ^, C- B" k5 ?4 s  X

" G' r7 \& R: b- V( H3 O% Z6 ?
+ E7 U# R% ~+ K( @. j关于多个词典CSS类名(class)重名问题,导致词典合并后样式混乱的解决方案5 y+ B6 d* V5 V& m. w. O
将词典源文本的所有类名批量改名,添一个前缀字符,再将该词典对应的.css文件里的类名批量替换,添加上该前缀字符。& w) v* ^" E; S8 a: m# e  l% e4 C
以《21世纪大英汉词典》为例,把词典源文本中所有的类名 class="example" 添加上 【cent21_】前缀字符(即替换为 class="cent21_example";前缀字符由英文字母、数字及下划线组成,且以英文字母开头),与其它词典区分开来。
$ m. h8 i/ e, e1 M# G% E% J0 s1. 词典源文本正则替换:
& x+ c& j5 j) Y. V* D
  1. class="(.+?)"
复制代码
替换为
  1. class="cent21_\1"
复制代码
6 _& p( Q* o6 k2 W4 |5 V  S: m* J
2. 将样式表文件(.css)正则替换:
4 Y# X8 M. x  Q
  1. \.([a-Z])
复制代码
替换为
  1. .cent21_\1
复制代码

/ j5 z4 d% y) D& e& y- @; p即可解决合集词典CSS重名问题。该方法仅对class有效。( R, A$ Z% S9 o: A  m

9 Z2 g9 j" [& E4 A# h
, S7 z+ y5 z9 |. j2 R2 i  u. b1 \6 N0 X" Z4 E
/ r$ B, e( n6 X0 ?- A6 a

+ k2 P* S5 _6 ~$ v& X! D) Z5 C; Q, A+ {/ d4 a0 x3 b3 X
& y( n+ L; f! {
& x, m5 ^$ q% E' h/ ^( m, d# X
使用过程中网友遇到的问题解答:6 D3 \; U* R' n, ?

( H  Q: r9 y! Q3 E! N1 b1 o第一类问题:合并词典的词条大小写区分问题4 v4 j# Y( d; t' v4 A; L. j
如网友VIPcoco所描述的问题: 36楼 place词条 language的内容跑道所有内容前面去了,mac下的欧路。3 C* @# f; h- R4 Z
及网友rit919所描述的问题:  32楼  wood的人名词条重复出现extras区的最底部,而不是顶部。查cook,bush等词也有同样情况。
* P2 ?. `3 \# s' Q$ {! @$ @) }* U5 K7 F5 f, c5 ~7 U- t/ d
原因及解决办法:  见原帖39楼   https://www.pdawiki.com/forum/fo ... &fromuid=203976  f/ h* |2 y% y4 r9 A

# T# e7 x5 M+ W, [& d  X  i. i3 i- _; j. d3 Q
第二类问题:词典合并后javascript脚本报错
( t5 U- c4 e! R& E1 _. |这种问题归结为两种情况( e- {( \! N. e- j9 G
1种情况:MDcict PC打开合集词典进入某个词条(还未点击切换按钮)时就弹出javascript脚本错误。
3 V8 ?2 D/ @' `( t' C+ ]0 p    这是由于个别词典个别词条内容下的源数据本身问题,也就是说原词典(合并前)在MDict PC中进入某些词条会报错,词典合并后错误仍然存在,导致合集词典(xin1)也报错。+ ?1 O( ^7 a% d; z) F& B
    这种情况只能找词典原作者修复词典。
% c' b& ~: \$ I2种情况:MDcict PC打开合集词典进入某个词条之后点击切换按钮切换词典时弹出javascript脚本错误。) i$ l9 q! z- n. y$ a+ E8 A
    这种还是词典源数据问题,导致程序新生成的div标签无法闭合,javascript找不到对象,导致切换词典时抛出错误。) e  {  ~* M. W( ~: O
    这种情况下导致合集词典(xin1)切换时抛出错误的原词典由于源数据差异,并不适合做该合并方式的合集词典。
2 ]2 X- {  d$ o0 {0 A* E! s# U    出现第2种情况时错误排查:' d! I/ u9 }+ R3 q7 `  u0 ]& c; X/ f
    比如:A、B、C、D、E词典合并后"farther"词条出现此错误(即点击切换按钮则报错),那么应该就是这五个词典中的其中一个或多个词典源数据HTML标签无法闭合而导致的该问题。具体排查方法如下:
) W) d4 w( f" |        1.将合并词典源文件后缀改为.html(用于显示语法高亮),使用EmEditor打开,查找正则:【^farther\r\n】,勾选正则表达式,查找定位到所查找的行。
4 o( Z8 {1 u- c, |        2.复制该项词条下的内容(HTML源码),创建新的HTML文档,粘贴到刚刚创建的HTML文档
- z$ z/ l6 c: @; i8 b         
' m: A' {* E5 C# |* X$ [4 d        3.将显示切换为“wrap by page”
$ m9 p: H+ J$ j$ s         
- G" g$ ~, t$ H          然后正则替换【<div class="dict_content_display】为【\r\n\r\n\r\n<div class="dict_content_display】,再将鼠标逐个点击到“<div class="dict_content_display”标签上,EmEditor自动着色显示该标签是否已完整闭合,若某个标签不能闭合,则就是该标签下的词典内容所导致的合集词典在切换某个词条时报错,这样就找到了源数据有问题的词典。! Q6 `( p( U! d
          。1 s$ j' j6 P5 T3 ~1 Q+ v
        4.最后一步就是修正有问题的词典源数据了,具体操作就要看情况而言了。  R, Y5 G$ N2 N* H

; ^2 c- k, O$ b8 f5 g
, Z8 O: R. K7 N! W" A' ?第三类问题:词典合并后的@@@LINK=# r, G) ~2 O4 r# m/ @2 L+ r* d! f
@@@LINK=这个用法我没有用过,不了解用法,不便谈论。# C# d8 @' o9 g% {
程序更新已解决这个问题,只是简单粗暴地用正则把@@@LINK=替换成跳转链接,点击便跳转到主词条。: p+ G: k/ ^" U7 ?8 K( T

, B  @4 ]' p) ^3 d5 Q9 `: _. O' L5 \3 q/ L" [
& M1 E* F- t+ R9 K+ n& P

) n8 {2 A3 Z# [- g
% Q; k% T% c6 Z" L; `/ \' F& J
3 b4 e( D3 w5 M) _6 I
2 ]/ ?' V" G. ?8 }& W9 X! B7 A+ H
1 w3 O8 f" R& o- y
4 f: G, h3 [6 O" S: {! D3 e# r

- F( ]7 c2 \" t  ]4 Z: e# }
2 @, g) P5 g3 S0 g# p5 p) i6 B8 a( H
软件(win64 only):9 S5 z/ g8 C  O; c/ M0 J3 o4 U& ^
( i6 X, j; |: Q  G+ y6 N+ o1 N

7 L+ z. ^. [0 @: i" x5 |5 E: T- F, M, i- i7 C2 N
5 k* V2 E- z* S7 J1 k; l- \

0 X; j% [5 _- c5 G3 m
) u  h; `1 f& E* a) |. U
8 R7 A: }* Y% A; ]
+ M4 G5 [  y( ?& s* T6 a+ M3 v* c7 Z4 e: K, N$ n! y
0 R1 `: g/ ^3 H, Q
- r3 w2 v1 l1 f5 Q" E+ Z- Y1 A
/ f; S( U( u4 k) C# B
& ^" o- \; }/ v- D
" w4 R/ M; H0 [1 {
------------ 请叫我线 ------------0 `9 C+ T$ p, r; H  D

. w' g" N8 P, ^% V* t0 S6 p
* x0 d. W8 g' H' t6 v如果你喜欢此软件,可以点开赞助窗口给我赞助
8 r+ _+ A  F  @, ^5 C2 X$ g0 `+ u1 U$ k" U
1 F2 L; {# g! J
→_→....    竟然不能隐藏密码。。。+ E  R0 f8 i+ S3 e  g/ ]
6 o. W$ E6 J$ d' \; a  y0 |8 c: g9 P
游客,如果您要查看本帖隐藏内容请回复

- @9 m$ Z  h- P2 z# S% L6 v9 F. b" _' H. v" _% R

9 A) ]$ H! _# x: ^1 I; g------------ 请叫我线 ------------
5 g0 q- y& d% R8 c" x# Z8 Y" O6 q  U
+ _, L8 Z% k. ]; u" [; a- q' \

% ^# W  R% [' {
3 F  C! ~( o. PMdict Editor Tool v2.0.356 S1 \& ?: u* Y
/ U4 g7 L7 |% c' D. t
软件功能简介:
8 W- w& ~& B6 F; R* A: w) q2 d0 _9 Y; ]  w5 J  K* I& t2 N
◆1.词典内容提取:
' H1 K# @  }* s2 j1 Z- p" a: k      ①按单词列表提取。
0 ^+ q4 ]) H* b5 n( {' E2 b" Z      ②按正则表达式提取。如提取例句、音标、释义等。
  S% l" u, D" X3 A      ③提取词典中所有词条。9 y/ v8 |3 ?* c+ R
      ④按HTML标签提取。
1 Z0 `. Z- |& ~' C2 D) N0 ]$ L$ Y. ~2 i0 q  X9 U  L
◆ 2.多词典合并:
% [+ A8 [5 C) H. _- u) K* U可合并多部词典,合并样式丰富,可自由选择样式。+ G& a. r, k# Z4 e( x; f" B
程序自动生成CSS、JavaScript文件。* v! F8 t# G1 ?( |. V2 T) [) p
理论上可以合并任意无限多个词典,但合并词典数量取决于电脑本身配置。% B; y" ]9 f* C% r
/ N( ~! V( _. `! s1 _
◆ 3.词典锚点与制作:/ W+ e5 g" e  j8 c+ A4 I
用于Mdict词典锚跳定位自动化制作,如词组短语、例句、释义、音标等多维查询词典制作。/ a& t' d1 G! y  N; D
# t/ A1 j$ q& ]: m9 H+ C( l1 K  G
◆ 4.词条合并:
$ o  I$ Q9 {% D1 [. B6 |, G只需确定词头的所在的标签,便可自动给词头的右上角加入序号。同时生成可定位查找的词头标题。" h! c9 s$ B- {
! \( E% z4 u' p9 S$ d
◆ 5.词条去重9 ~5 ^3 N" o2 P* N; P. f( H! ^+ M
9 d+ X5 Y/ J* O

: Y: c8 a4 @4 N, s' ^4 o0 \; L◎ 启动软件时部分功能已经预设完毕,刚开始使用此软件的同学可直接点击右下方按钮尝试制作。

本帖子中包含更多资源

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

x

评分

4

查看全部评分

本帖被以下淘专辑推荐:

该用户从未签到

 楼主| 发表于 2017-2-24 17:46:50 | 显示全部楼层
本帖最后由 spoiltbrat 于 2017-2-26 21:20 编辑 ) L1 T  Z5 a9 W$ J1 D
+ \/ S8 u) D$ g: z9 g
现将程序上传至论坛:
: H" P+ F: H4 R: m0 r6 D  E; F& f) @0 b6 `' x+ L' N! h
程序在后期使用过程中发现合并后词典内容版面调整不方便,于是补充了一点代码上去,便于词典内容版面调整。

* E1 @6 v: b3 B+ A2 A. D9 j& H2 \7 @. ^% \) ~

+ z2 V2 x  l7 @, D
2 K$ ?) c3 Z# h. ?

该用户从未签到

 楼主| 发表于 2017-2-21 17:48:55 来自手机 | 显示全部楼层
暗潮涌 发表于 2017-2-21 15:567 r' z, d& O+ i
谢谢分享,很喜欢这个软件,有一个小请求,就是目前只支持单行正则提取,能不能加入多行正则提取,notepad ...
& |' h, P1 A8 A; t" [8 h9 r+ J
软件不再更新了。
  • TA的每日心情
    擦汗
    2019-12-19 17:46
  • 签到天数: 3 天

    [LV.2]偶尔看看I

    发表于 2016-11-17 16:30:09 | 显示全部楼层
    非常感谢分享软件,
    - T7 e9 t: M. Z& w发现在win7 64bit下出现
    : ~$ [( ~* w, ?: G% K. i"Mdict Editor Tool v1.2.exe 已停止工作"8 ?. x0 m9 K' N! r; n2 x) T2 a
    无法运行程序
    8 |: F2 e+ b) ]' l& g7 u; P, n  M* B, l8 k8 m( I

    该用户从未签到

    发表于 2016-11-9 20:40:16 | 显示全部楼层
    感谢楼主制作工具,真心佩服!

    该用户从未签到

    发表于 2016-11-9 23:42:20 | 显示全部楼层
    謝謝 spoiltbrat,你的新工具很棒。

    该用户从未签到

    发表于 2016-11-12 15:33:41 | 显示全部楼层
    要是能直接根据单词表提取文本,图片,语音等内容制作小词典就好了

    该用户从未签到

    发表于 2016-11-12 17:16:42 | 显示全部楼层
    支持,虽然看不懂是什么东西
  • TA的每日心情
    开心
    2019-6-27 09:54
  • 签到天数: 152 天

    [LV.7]常住居民III

    发表于 2016-11-15 18:56:17 | 显示全部楼层
    这也是一个好工具,但还没来得及用,不敢妄言。
    6 D' o( j1 Z2 {" O$ G# O+ @
  • TA的每日心情

    2019-11-23 08:34
  • 签到天数: 104 天

    [LV.6]常住居民II

    发表于 2016-11-17 10:38:26 | 显示全部楼层
    Win10下运行没反应......

    该用户从未签到

     楼主| 发表于 2016-11-17 10:45:58 来自手机 | 显示全部楼层
    怪物猎人哥 发表于 2016-11-17 10:38* L9 B) v& |! O4 t
    Win10下运行没反应......

    * \4 e. k; z) l4 R! n我只在win7上测试过,win8、win10的还不知道情况,等会儿我弄一下,发布个兼容性版本
  • TA的每日心情
    难过
    4 小时前
  • 签到天数: 604 天

    [LV.9]以坛为家II

    发表于 2016-11-17 10:58:13 | 显示全部楼层
    谢谢分享的好东西!!

    该用户从未签到

     楼主| 发表于 2016-11-17 12:12:46 | 显示全部楼层
    怪物猎人哥 发表于 2016-11-17 10:38
    . M; v% _9 n/ `* {Win10下运行没反应......
    * A7 V/ o* \3 n& Q1 l8 J0 W
    刚才在win10下测试了一下,没问题的;只是程序界面有些变化。

    该用户从未签到

    发表于 2016-11-18 11:27:53 | 显示全部楼层
    任意单词列表(txt),除了能从带语音的词典中提取释义外,能同时提取对应的语音文件不(以当前单词命名,若多个语音(英音/美音),能够自动标识)。: n4 ]2 M4 |& g* ^

    9 Y7 O8 c: q4 g* K0 d谢谢您。
  • TA的每日心情
    开心
    2018-12-9 08:17
  • 签到天数: 3 天

    [LV.2]偶尔看看I

    发表于 2016-11-20 05:44:24 | 显示全部楼层
    好工具,拿來学学,謝謝!

    该用户从未签到

    发表于 2016-11-20 08:03:06 来自手机 | 显示全部楼层
    本帖最后由 lzr80 于 2016-11-20 10:36 编辑 % D7 Y8 p3 b* g  b4 N6 E

    % `' q5 o: Q" a; i/ B. n: \! O! t请问合并后各词典的css,mdd文件如何调用?

    该用户从未签到

     楼主| 发表于 2016-11-21 18:35:44 | 显示全部楼层
    lzr80 发表于 2016-11-20 08:03
    ; _, f0 a+ v' E/ w5 c2 F请问合并后各词典的css,mdd文件如何调用?

    ; ]1 j/ |6 G7 [, Y* ?3 Z把各词典的MDD资源(或CSS文件)与合并后的词典放在同一个文件夹即可

    该用户从未签到

     楼主| 发表于 2016-11-21 18:38:03 | 显示全部楼层
    dhs1001 发表于 2016-11-17 16:30
    ) k1 j( ^) K% o非常感谢分享软件,
    $ X5 g& |8 u  \发现在win7 64bit下出现
    9 j9 f. G; |! M2 ^8 L/ K1 M  O"Mdict Editor Tool v1.2.exe 已停止工作"

    ! ^  O$ E: q( q5 g2 m( T本次更新问题已解决了

    该用户从未签到

     楼主| 发表于 2016-11-21 18:41:07 | 显示全部楼层
    ok927 发表于 2016-11-18 11:27
      S$ D, C; Y9 t' A, O+ U; D任意单词列表(txt),除了能从带语音的词典中提取释义外,能同时提取对应的语音文件不(以当前单词命名,若 ...
    , }% h& W4 q) S1 A. }5 I( _( V

      d. S/ V# ^  k- O+ d这个很简单啊,没必要把这个功能添加上去

    该用户从未签到

    发表于 2016-11-21 23:01:31 | 显示全部楼层
    不是的。
    3 ?/ d- V# {4 `2 |) {! Q9 d( n如果我提的功能可以实现,就可以从词典中提按需提取语音文件了。

    该用户从未签到

    发表于 2016-11-21 23:24:59 | 显示全部楼层
    很想试试这个新式武器。

    该用户从未签到

    发表于 2016-11-21 23:37:10 | 显示全部楼层
    软件很强大,谢谢。在标题跳转模式下只能从上往下跳,好像不能跳回来,是吗?

    该用户从未签到

     楼主| 发表于 2016-11-21 23:37:36 来自手机 | 显示全部楼层
    eeshu 发表于 2016-11-21 23:24. ~# [% D- R% d- c
    很想试试这个新式武器。

    ( j+ d5 C: ?3 G3 S7 V# X' W* e4 q除了UI代码部分,这个工具纯手写的有一千多行代码啊……(当然部分功能借用了之前写的代码)

    该用户从未签到

     楼主| 发表于 2016-11-21 23:38:45 来自手机 | 显示全部楼层
    eeshu 发表于 2016-11-21 23:37
    8 Q% L+ y* [6 }) G软件很强大,谢谢。在标题跳转模式下只能从上往下跳,好像不能跳回来,是吗?
    ' o, w# [5 G6 Z+ Z2 }& ?
    2 H" X3 d8 G4 k
    为嘛还要跳回去呢,好像没必要吧。
    您需要登录后才可以回帖 登录 | 免费注册

    本版积分规则

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

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

    GMT+8, 2020-4-7 11:46 , Processed in 0.163766 second(s), 9 queries , MemCache On.

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

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