|
本帖最后由 spoiltbrat 于 2017-3-27 23:00 编辑 4 j7 z# B# A0 h: c+ M3 N& J
: c# b# f1 H6 }$ i0 X. d" |
Mdict Editor Tool v2.0.35 -- 多功能个性化词典制作工具
4 ` N* O3 e# K+ U! B& K' C: x5 g+ L8 ]% V# B" t
+ K$ p: y6 X8 a' \5 O
9 p- F+ `$ M: B& r; g2017.03.27: @0 l/ A- @" b. D% P
发现bug,修正更新。9 I* W; d& m3 u: @
0 k- G# K9 z3 w2 ^, E6 p" c: n2017.03.15: X( J/ w, ^4 q# r: y( U- K" j
新增提取功能,按HTML标签提取,速度虽然比不上正则,但简单易用,适合没有编程基础的同学,提取更方便。
T& D( J7 M$ ]* h" a正则虽强大,速度快,但处理HTML多层嵌套标签就显得力不从心了。
* l( i% X$ F7 B4 v- E$ o4 h, c此功能依赖第三方库lxml,软件打包后体积也略大了一点。) i7 j9 G0 K" w1 N7 G
( t1 H0 n" i$ F5 @/ ?
5 m9 p" ?/ P* ~# e" H4 ~4 o
/ C O( [3 q. s [+ |
( Y' Q" ^ [5 T1 o关于多个词典CSS类名(class)重名问题,导致词典合并后样式混乱的解决方案:7 ~/ N( w5 o: F5 L' y8 ~' T
将词典源文本的所有类名批量改名,添一个前缀字符,再将该词典对应的.css文件里的类名批量替换,添加上该前缀字符。% ?4 H3 v( x' T' A D! J& M' H- ^
以《21世纪大英汉词典》为例,把词典源文本中所有的类名 class="example" 添加上 【cent21_】前缀字符(即替换为 class="cent21_example";前缀字符由英文字母、数字及下划线组成,且以英文字母开头),与其它词典区分开来。( Y2 R# T& r5 t! s( V: p5 Z
1. 词典源文本正则替换:* q6 ~& R7 \0 ^* H
替换为/ ?* s6 R( h; J/ F; {
2. 将样式表文件(.css)正则替换:2 N; A) V2 F. o o& o" u( U
替换为
1 Z4 k3 ?9 x4 G1 |& [: O即可解决合集词典CSS重名问题。该方法仅对class有效。
! d, R/ h3 L$ A6 l
3 c& e, b6 g* S8 q6 f. `/ I5 k% K1 |1 w* y, Q
" C u. h5 k! d/ M U- H& C; p, H7 Z6 ~8 R/ k0 v
& ~: D' j0 V+ b
! X( m5 P! r: R3 O) q, g
6 ~# g$ U7 U+ x y2 ~0 R! u7 Z6 k# j) H- A0 A# f7 s3 j
使用过程中网友遇到的问题解答:) s3 c, L, ~+ I) X# X' t7 |
" B5 s' v+ J3 h' L% a第一类问题:合并词典的词条大小写区分问题
! B2 j5 T; B! X如网友VIPcoco所描述的问题: 36楼 place词条 language的内容跑道所有内容前面去了,mac下的欧路。
. Y& _& u, c, i及网友rit919所描述的问题: 32楼 wood的人名词条重复出现extras区的最底部,而不是顶部。查cook,bush等词也有同样情况。
\0 M* I- x8 D, t! P4 a6 s' k9 [+ a1 N4 K) Y) r2 T) [/ [+ u
原因及解决办法: 见原帖39楼 https://www.pdawiki.com/forum/fo ... &fromuid=2039762 ~" I' t* k8 \ V i
' O1 l5 B) |9 M5 R7 [' f+ T( u- F1 c; _
第二类问题:词典合并后javascript脚本报错8 [) J1 ]( {3 ^% R+ R/ U+ B. d
这种问题归结为两种情况:( Z9 }! C, v J2 p/ s- M0 U( Z- ^, g
第1种情况:MDcict PC打开合集词典进入某个词条(还未点击切换按钮)时就弹出javascript脚本错误。
+ A) f. }0 N7 f1 ^3 X b& F 这是由于个别词典个别词条内容下的源数据本身问题,也就是说原词典(合并前)在MDict PC中进入某些词条会报错,词典合并后错误仍然存在,导致合集词典(xin1)也报错。
' M8 B# D7 ]5 N# @ 这种情况只能找词典原作者修复词典。& q! A9 W1 s; a- s6 j! N& d4 ^+ z7 O
第2种情况:MDcict PC打开合集词典进入某个词条之后点击切换按钮切换词典时弹出javascript脚本错误。: T/ P5 m0 A$ [" e4 e2 B1 P0 G
这种还是词典源数据问题,导致程序新生成的div标签无法闭合,javascript找不到对象,导致切换词典时抛出错误。. t' y# u1 x+ U9 X
这种情况下导致合集词典(xin1)切换时抛出错误的原词典由于源数据差异,并不适合做该合并方式的合集词典。 6 ?- o/ D9 `- j' Z
出现第2种情况时错误排查:
5 L( q: e; F, ?) Y3 e3 r3 U0 K' z 比如:A、B、C、D、E词典合并后"farther"词条出现此错误(即点击切换按钮则报错),那么应该就是这五个词典中的其中一个或多个词典源数据HTML标签无法闭合而导致的该问题。具体排查方法如下:* a2 ?% A8 ]& b# j- u8 o0 |+ A
1.将合并词典源文件后缀改为.html(用于显示语法高亮),使用EmEditor打开,查找正则:【^farther\r\n】,勾选正则表达式,查找定位到所查找的行。
0 ?, h: J5 u0 H. d- w, M 2.复制该项词条下的内容(HTML源码),创建新的HTML文档,粘贴到刚刚创建的HTML文档" ` ~0 \" B/ R7 K* ~& b; {8 p& }
1 i! S& P2 @; g7 u: v, g 3.将显示切换为“wrap by page”3 I. _$ P9 u G4 s) C* S
1 w" j1 W0 q! F( }0 ` 然后正则替换【<div class="dict_content_display】为【\r\n\r\n\r\n<div class="dict_content_display】,再将鼠标逐个点击到“<div class="dict_content_display”标签上,EmEditor自动着色显示该标签是否已完整闭合,若某个标签不能闭合,则就是该标签下的词典内容所导致的合集词典在切换某个词条时报错,这样就找到了源数据有问题的词典。
3 t2 f% p! h- _3 L4 ^ 。" Q/ h* V s/ H5 } \, ~
4.最后一步就是修正有问题的词典源数据了,具体操作就要看情况而言了。! P h) W9 }- B
7 w: \0 E0 E; g( P u6 c# U: ~% Z
/ k8 C) |" d e9 E/ y
第三类问题:词典合并后的@@@LINK=* N. e/ m& R7 s
@@@LINK=这个用法我没有用过,不了解用法,不便谈论。; j8 y7 j( U$ X1 J8 S& G# }
程序更新已解决这个问题,只是简单粗暴地用正则把@@@LINK=替换成跳转链接,点击便跳转到主词条。7 x6 q/ Z6 v* a* P* ?
6 d" ~( b. y# }4 }. F! G) {1 Q7 P% _
7 n/ f( ]2 l( Q( i' i2 T3 C& L3 T0 B' y: [' y
, T( n$ w! `6 W# e j$ E% Z' E- L. z: @2 A4 |
+ t2 v: G; y9 l
7 H/ N& k. \1 B" t, o5 Q# d; N. \6 H3 h' T. i
3 j' f5 a' o! ]0 A- E* [3 b' V
1 {% i0 R& P$ s& j/ ^0 S
* D& l5 y8 ?4 O0 j# T4 e+ ^
7 R- P1 A8 A* F9 c/ o软件(win64 only):4 B) ~1 }& y6 y, V6 h
$ |, U+ d, [! r, r3 X7 i0 L! p( [ ~! O+ E f1 O
" c, K2 y$ `& U! ~
! ^- h$ B& l3 M% d$ ^0 E
+ A( F' G; m+ p# M2 _
4 q2 i5 p# ~& V4 _
7 ^- u( D4 X- ]
2 f4 {/ y( O' ?% r% b) `
3 L1 L4 T3 j5 K; I$ S: ~* _3 |/ P0 g; X0 I* t
) O, h1 |3 x4 U1 O2 c+ C7 R
- q0 |. I0 f/ d2 Y( B; h
0 N/ A7 @% m6 F7 W8 z" T0 S
+ F. m4 i# e2 Z, V# x& P% M4 o6 l------------ 请叫我华丽的分割线 ------------4 {4 N! y% X0 T: Z- ]7 U
: c# J( v3 Z1 L, d
K$ g* }; M" Z# D3 r$ ^如果你喜欢此软件,可以点开赞助窗口给我赞助。
' g+ {( i8 B' V- ]% D5 s$ w
: s( R& u# J. w. A6 O7 C, x* r, R. J- p/ a3 `, h" Q1 y& Z/ |$ H& t
晕 →_→.... 竟然不能隐藏密码。。。" V. b: ]0 y6 W3 J
& v0 \- @# ?& s: i
1 p) a3 T$ L( K! ]$ b& w3 e( N
4 W1 P9 N/ t: z% ~4 u) K! q: N( f# W
4 k4 D2 o/ {# @
------------ 请叫我华丽的分割线 ------------
* S8 W( E6 b* `" Q
/ Y! \" j4 r5 H0 M8 K$ ^ u6 z5 V
* J, _0 Q/ q( j# h W3 i
. [6 S( s% `% g# w5 k6 n
5 J7 P. F8 `9 T. c) r0 w; b+ eMdict Editor Tool v2.0.35
( c' I+ v2 P" t6 G" M
4 ?, R; D. M! A) b软件功能简介:
1 [: t0 t2 _( d% O& v7 U; j6 I+ g; r
◆1.词典内容提取:2 M' T9 f* H% F) D5 k4 b; v% z( k0 ?
①按单词列表提取。 @$ q% E) h" r( j$ U: Y5 F- v
②按正则表达式提取。如提取例句、音标、释义等。3 q) z6 E0 K6 R: ^
③提取词典中所有词条。2 t6 [& @4 o* J0 c3 m$ n
④按HTML标签提取。
% E9 D5 v9 m6 n1 ~& g A# C1 J6 ]$ H* O# S K8 z
◆ 2.多词典合并:1 k3 v9 `1 A8 F
可合并多部词典,合并样式丰富,可自由选择样式。0 n4 K: q9 P, {7 k( k) K6 {) `
程序自动生成CSS、JavaScript文件。
3 l1 D; x5 E# t$ X" @$ G7 _. k理论上可以合并任意无限多个词典,但合并词典数量取决于电脑本身配置。
8 X* l/ P' T Y* D, F# F2 z+ C/ c, b+ ?3 n! K
◆ 3.词典锚点与制作:
- | K. A4 \1 Q# [4 t# _用于Mdict词典锚跳定位自动化制作,如词组短语、例句、释义、音标等多维查询词典制作。
# O2 t% Q8 z" x! Q) }+ Q, b8 _% R
◆ 4.词条合并:. G0 ? Q+ j5 n* ^
只需确定词头的所在的标签,便可自动给词头的右上角加入序号。同时生成可定位查找的词头标题。
8 p8 k+ }2 F" }( z" B0 A
: W' Z( X/ o6 y, t) I# X◆ 5.词条去重$ s, \- _# x) z6 `* N
* e% q. V% H( G! X: ~( h- {3 L" T3 \# { T7 o8 ~( h3 p" _
◎ 启动软件时部分功能已经预设完毕,刚开始使用此软件的同学可直接点击右下方按钮尝试制作。 |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?免费注册
x
评分
-
6
查看全部评分
-
|