|
本帖最后由 qunwang6 于 2017-6-9 00:23 编辑 4 y: K# W+ F* Z5 G, m: n. n
. V" _# |8 C1 a1 u. h
/ N, W* f* e) I4 a3 Q6 F* T% Z7 _20170609更新:
G; O3 u( v) ~5 e- h- c0 `新版pyglossary 要安装以下环境:sudo pip3 install lxml beautifulsoup4 html5lib ! B% F# k, c& W) |- V- }
Python 改成Python3 6 G/ U1 e1 w3 F' v- l3 Q! b
✍准备好以下环境:
& K# [, s2 M7 a* BeautifulSoup4 required to sanitize html contents.
% Z; I" q, H* J8 z5 esudo easy_install beautifulsoup4 html5lib& u, F7 D/ ]% n' b0 @ b) K3 C j
* GNU make as part of Command Line Tools for Xcode.
9 i- f7 ^2 s8 L8 @" R+ h0 q. ihttp://developer.apple.com/downloads
0 a# ~) k' l- x: G* ^* Dictionary Development Kit as part of Auxillary Tools for Xcode
7 G k# `7 o; ~9 u. o: H: w1 g" Ihttp://developer.apple.com/downloads.
3 v' |1 a2 B$ d2 p% @# b' s将Dictionary Development Kit解压到/Applications/Utilities/DictionaryDevelopmentKit/# q- J6 J1 P" _$ j) ^
(不含空格,中文名:应用程序/实用工具那里,也可以解压到其它地方。)
5 `% P* Y. f4 K* O5 D" X
( K6 a* P u/ E5 I& Z
' n+ F( o( i3 I& W+ l! ZBGL ===> OSX.dictionary
% ?! ]3 J" x" j" |转换- python pyglossary.pyw --read-options=resPath=OtherResources --write-format=AppleDict dict.bgl dict.xml
复制代码 编译
( A }9 P4 g/ S7 P% @3 _) T* 修改Makefile里2个参数,DICT_NAME是生成文件的名称,DICT_BUILD_TOOL_DIR是Dictionary Development Kit的路径,如果错了就不能生成文件。$ [& b1 I6 [4 {$ {
* 修改Info.plist里3个参数,CFBundleName是在Mac字典程序工具栏下面显示的标签名,CFBundleDisplayName是词典名称,CFBundleIdentifier是词典的ID,需保持唯一性。。
6 J% Q8 y" V/ l) L0 C* 根据模板格式编辑Dictionary.xml、Dictionary.css,如果有图片则放置在OtherResources/目录下.
6 B. ]) f: |4 z; N& I5 R2 o, }* 打开终端,cd进入模板文件目录,输入make,稍等一段时间,即可生成字典文件,将object目录下生成的dictionary文件拷贝至 ~/Library/Dictionaries,打开字典程序,即可看到生成的字典。
. i w* X1 e9 m. L或者直接用make && make install这个命令,生成词典后直接安装到了~/Library/Dictionaries。% Y" o4 h; a) m2 W+ ]: p: N0 Z" P( n
9 e& ]/ a% e8 ]! h& i**注意:如果OtherResources里的图片太多的话会出现以下错误:**1 f7 }9 Y. I3 j) b
/Volumes/Macintosh HD/Applications/Utilities/DictionaryDevelopmentKit//bin/build_dict.sh: line 206: /bin/cp: Argument list too long8 j- r* r, Q# B' ^
Error.
8 E U$ w! |8 V ]% V3 @6 z! t( ]& Smake: *** [all] Error 1
# E9 m, _$ I) k5 O
! d, L% s2 Z$ f8 B9 g- n. N可以在编译前不加入图片、语音文件,在编译完成后将图片、语音文件复制到xxx.dictionary/Contents目录下。
$ A; H4 K- K E1 e' B. s) f) H% P" ]2 s5 p# V
# }* a8 a) {6 Y$ ?/ x2 Z3 R) E# h' M+ L3 ~, N9 m
DSL ===> OSX.dictionary2 y4 _, a' ]! H
& s' ^* u) ^1 O4 X& b. g1. Convert DSL from UTF-16 to UTF-8:- iconv -f UTF-16 -t UTF-8 dict_utf16.dsl > dict_utf8.dsl
复制代码
& a% j- S, x9 M) d6 g4 [2. Using pyGlossary python project, convert UTF-8 DSL to AppleDict XML:- python pyglossary.pyw --read-format=ABBYYLingvoDSL --write-format=AppleDict dict_utf8.dsl dict.xml
复制代码
; V6 |6 Q- ]4 Q0 d2 x; c5 W9 u**lingvo格式.dsl转换成可发音的词典。(注意修改命令参数)**↓; a6 c8 Z% G8 T
audio conversion is optional, "no" by default. The following command works,* U# N3 Z( E/ @
~/Development/pyglossary/pyglossary.pyw --read-option="audio=yes" test.dsl test.xml2 i8 L6 X3 X4 l0 O
make && make install - python /Applications/Utilities/DictionaryDevelopmentKit/pyglossary/pyglossary.pyw --read-options="audio=yes" --write-format=AppleDict ldoce55.dsl ldoce55.xml
复制代码 / `# K4 n2 b% Q0 K
3. Using Command Line Tools for Xcode and Dictionary Development Kit:编译步骤同BGL ===> OSX.dictionary, _0 [3 R ^! V4 `) C) R
- make& D% {0 @1 v1 D! B- m( n
- make install
复制代码 2 v1 h6 l" }- i6 D
. H; ^; v3 [& m" d+ |
MDX ===> OSX.dictionary
- V/ L! b1 `7 N. P8 A* \
: V9 h7 X1 I, t7 b转换 * @0 Q2 n4 B! X9 J
- cd ~/Downloads/oald8/6 D1 d8 E. R( k% m
- ~/Software/pyglossary/pyglossary.pyw --read-options=resPath=OtherResources --write-format=AppleDict oald8.mdx oald8.xml
复制代码 9 |" \* ^1 d' @
修改.xml文件里的链接(如果不是可发音的词典,以下两步可略过)
" A T3 w6 y/ |. S9 g, M- sed -i "" 's:src="/:src=":g' oald8.xml
' F2 P+ o% F4 a) N5 x - sed -i "" 's|sound://\([/_a-zA-Z0-9]*\).spx|\1.wav|g' oald8.xml
复制代码 第一个是去掉"/". i) e& B0 ~' a# O' Q- w
第二个是去掉”sound://" ,".spx"改成".wav"
% p' X$ J* s* w) ]% x: m* {- s& J# j0 D# @" ^# y
将.spx语音文件转换成.wav(需要安装speex,麻烦!可直接从lingvo那里复制,或者直接从原光盘提取)- find OtherResources -name "*.spx" -execdir sh -c 'spx={};speexdec $spx ${spx%.*}.wav' \
复制代码
! t, H. t4 r& w6 H' H编译步骤同BGL ===> OSX.dictionary
* p7 }; i* G5 E8 y& b1 B注意:如果OtherResources里的图片和语音文件太多的话会出现错误,可以在编译前不加入图片和语音文件,在编译完成后将图片复制到xxx.dictionary/Contents目录下。
9 u& ~) Z" R/ t. J. X ! B, e& H% M7 x, |
CD(原词典光盘)===> OSX.dictionary
3 i# @. ?8 }' k5 J0 {# m3 Y以OALECD8为例。
- ~- Q2 o; g2 z! H2 H6 n% p& D数据提取:虚拟机xp+python2.7,用IDMSKconv提取。) ~) n: l, Z# O. W
制作:从OALECD8安装目录下找到oalecd_master.css.BAK、从提取出的数据里找到output文件、以及图片和语音mp3文件,复制到Mac OSX下备用。
4 l, L8 z$ r& u! X( A将output文件重命名为oalecd8.xml,oalecd_master.css.BAK作为CSS文件重命名为oalecd8.css,从Dictionary Development Kit里找到模板文件分别复制出MyInfo.plist、makefile文件,MyInfo.plist重命名为oalecd8.plist,修改oalecd8.plist和makefile里的参数。1 E& M* ~; m$ x: l
排版:里面各种奇形怪状的标签可以不必修改,有oalecd_master.css.BAK作为默认CSS,所以只需要在oalecd8.xml里添加头部和尾部,删除不要的东西,就可以编译出和原版相同的词典。7 s! t: J4 n6 z, M
......
8 w6 h( e* R( f7 a5 B $ T8 D- ?2 H# `6 |
###参考:
$ M7 s, S5 }5 }+ }) H# \! C1 z) A8 g* GoldenDict Mac OS X available - Early Access Builds
. k/ ?3 C' z# Q" n* PyGlossary Overview . t u1 E; Y# Q3 y& ]
*https://developer.apple.com/libr ... /doc/uid/TP40006152
4 |9 t9 Z& O: {2 u( F; g
& }# }2 I* t" C: k3 X! J8 u7 v细节部分
( w/ o' y% K4 ~! g. C$ Z. _/ y
1 C) Z' F& d8 u, V0 H( }v======* 注意修改单词内部的链接========v
/ i% s# S( j- U单词跳转用x-dictionary:r:& z0 r3 B N# H ?% i
(只能在当前词典内跳转且x-dictionary:r:后的单词大小写须与d:entry id="***"里的大小写一致,不能有空格否则不能跳转。)) r6 `* W2 n( g) s/ l
+ W/ U8 s! b: U# i' A( s
单词查找用x-dictionary:d:
: v$ F& k+ B- I% N, d(会先搜索当前的词典,若没有,会调用其它词典搜索,不限大小写、空格。)6 j& a+ y" ^+ E
(基本上都是用r,用d很少). h; G, l1 x0 R) H
^==============================^ `6 T9 U1 R7 _7 ^& Q. L
The x-dictionary: URI contains three elements separated by colons as the general form—target selector, target text, and dictionary bundle ID. The target selector must be either d (for definition) or r (for reference). Use d if you want to search definitions of the following key text. Use r if you want to refer to the entry specified by the reference ID which must be unique to each dictionary. 辞書.appの辞書を引くURLスキームに
2 x. i4 k& R+ B$ _2 q次のようなものもあります。: b* B/ Q1 G3 |% n- F a5 t
x-dictionary:d:key_text:dict_bundle_id/ m0 f1 Z! F' `
x-dictionary:r:reference_id:dict_bundle_id6 a0 H. K3 @( ~/ ^6 M4 D
**1key_text 調べたい単語
, Q& _* \6 `! R" l; F4 Y**2reference_id 辞書を作るために作成するdictionary.xmlの4 y- ^, C( s# {! b
各タイトルごとに割り当てる固有のエントリーID7 E! _, R: X4 v4 a$ m: Z. A1 A" b7 c
<d:entry id="0ABCDE" d:title="案の定"> 0 S4 F' v5 {2 [1 S
* ex.
: N! e5 c0 p" q3 | l' U1 R8 D9 N1 _7 `1 z7 n0 }7 S0 D4 L
1 v. x" A* ^4 \ <d:entry id="make a face" d:title="make a face">5 Q3 n# h+ L M* Z; t4 \: ^& q
<d:index d:value="make a face"/>
3 f; T. L9 y- D# T <html><body><h1>make a face</h1>1 g, w3 h5 n8 j: d) F
<a href="entry://grimace">grimace</a></body></html>( m6 q3 [ k; V& B* ^ X
</d:entry>
- w( A# W: K, }, j) B
4 F$ b9 w+ l7 v2 a5 y) H" O/ M <d:entry id="make faces" d:title="make faces">1 c. f. I3 O: t: H9 ?, z q
<d:index d:value="make faces"/>
$ o- f1 d9 W% s <html><body><h1>make faces</h1>: t) l1 @; j5 f. P; O
<a href="entry://make a face">make a face</a></body></html
' R0 u4 c4 [$ g6 a8 m </d:entry>
# S- h7 h3 ~1 [& b5 m* b, O& |6 P* n' S
"entry://grimace"% z- c+ U6 x2 q+ u. t2 y
将entry://替换为x-dictionary:r:
& E/ \( q0 ]3 K9 I: k===>"x-dictionary:r:grimace"
/ |/ x* O9 u6 o8 [! d8 y5 ]1 |7 P6 f' p' D$ N& l! n6 O+ h6 e+ v
d:entry id="make a face"" e. J" @) W5 ~6 k" V. ]
href="entry://make a face"+ a; K" e) y, ?8 a( G' R/ H
类似上面的单词,中间不能有空格,否则单词间不能跳转。
[! T; T# w, _8 Y===>- Y5 J7 U, T0 J0 h& m7 i( U' J
d:entry id="make_a_face"
8 I! @# _7 c! h7 i5 }! ~href="x-dictionary:r:make_a_face"9 i( W$ @! p" l% A
替换空格需要用到的正则表达式:" H* i" \! |, F' a6 B
(在此感谢ryuya,https://pdawiki.com/forum/thread-13044-1-1.html)- (<d:entry id="[^"]+)\s替换为\1_
复制代码- (href="x-dictionary:r:[^"]+)\s替换为\1_
复制代码 9 i( |- F4 L- Q* h& _- _3 j5 Q4 {6 W" q
v=========词组/词性跳转、定位===========v
$ O. s5 v) F, \' C( s' _2 }! I词组/词性页面内定位
9 ]$ V# m4 Q/ o$ w. V+ O<a class="LP_OS" href="entry://#L_hkx1">suffix</a>3 l# a# K6 J1 C: p3 Q9 V$ C0 U
<a name="L_hkx1"></a>) Q* ?8 T) X; E2 I r2 _: j$ [7 F
==> <a class="LP_OS" href="#L_hkx1">suffix</a>
8 U1 ^4 h Y) u6 E$ \. U------------------0 N* j8 k& V. f9 T o
词组/词性跳转并定位/ P# N$ V; q" d7 E( [3 U+ t) R) Z: K4 T. \
<a href="entry://clip#ld3097">clip</a>- N, K, D' l: w& m8 ?; a
<a name="ld3097"></a><span class="L_IDOM">$100 / 50 cents etc a clip</span>2 |2 d0 o; o2 Q- Q$ K! K, v+ `
==> <a href="x-dictionary:r:clip:#ld3097">clip</a>2 @' E: R+ W8 Y. p9 {" Y
用到的正则表达式:
4 }+ e5 q. E) ]" `1 x8 I Ex-dictionary:r:(.+?)#
: y3 L, ` M1 Z# F) Z, H替换为:8 i9 j. G# g" V4 U! A4 u
x-dictionary:r:\1:#
, P( ^4 Z$ X9 [" R相关的词典:朗文当代英语词典英汉双解第4版* @# N7 N. J; d4 f5 `% K
Shorter Oxford English Dictionary Sixth Edition$ ~' D6 D2 _4 ^$ I4 B* q: |- M
^=========词组/词性跳转、定位===========^. ?. N6 e; o {) U. E0 x2 {: G
% [+ ^" E: B6 d+ l' C
2 v. T' @+ c3 h# ~另外一个开源项目
( E& Y& C. P' W9 B0 b3 NDSL to OS X/iOS dictionary converter(相关教程可到我的空间相册里查看)9 @1 j) c$ u6 z$ t
https://github.com/svintuss/DSLConverter8 J6 L% u$ h) o1 v
StarDict转换工具
9 ]# b8 E, Q5 e5 Xhttps://code.google.com/p/mac-dictionary-kit// b$ M! n. M; X; Y; ^
关于金山字体问题3 z" M; J. ~' G6 `
http://www.linuxsir.org/bbs/thread363915.html4 A5 R+ ^8 g+ t- Q9 x' ?. f8 L
许多Linux词典也使用了Kingsoft Phonetic Plain字体,但是能下载到的金山字体一般都不是unicode编码的,导致Linux下音标显示为方框。实际上用FontForge修改一下金山字体即可使用。* n5 ? [ S ]/ M
安装FontForge:
4 _4 X/ [7 u9 [. \ @5 X9 R9 D#urpmi fontforge
' j5 l+ H+ i9 V% o0 U" ?( a& R" b然后用FontForge打开金山字体文件,你可以看到FontForge对字体里的每一个字形都分两行显示。上面小的是字符的名称,下面大的就是那个字符的字形了。金山字体本来是对普通拉丁字符赋予音标字形的一个字体,但是因为它不是unicode编码,在Unicode的拉丁字符区一个字形都没有。( g8 x8 e/ n3 {$ B
所以首先要找到金山字符的位置,比较靠后。注意从一个空格字形开始的。这个空格很重要,因为空格和之后几个符号的字形跟普通拉丁字符的字形没有区别,所以我们用来定位所有的金山字符。
; F3 ^- W: ~* s" d" B( \+ _ u2 I找到之后,从空格开始选定所有的字符,大约有三四十个。剪切之。2 b4 W$ b; F, c+ e
然后找到拉丁字符区。可以看到所有的字形都是“X”,也就是空。找到表示空格的那个字符位(U+0020),选中,复制。所有的金山字形就按照顺序复制到这个字符位以及之后的字符位去了。) h7 Q$ I) O2 P {
最后保存成.ttf文件就OK了。保存的时候会有一些提示信息,照着做一下就行。2 W& d' L; D( H+ {
顺便发一个做好的.ttf文件。仅为技术探讨,版权归原作者所有。 % J2 b1 O; u1 ?- L! a
$ a# m# |! u- x/ c8 i' {5 |
6 Q" j5 M% h9 I S
一些小技巧
! P s2 |7 {# L2 i* }Mac osx 下可以用三指取词,但在一些第三方软件下是不起作用的。) p8 d5 w! e' g' [3 @& k7 W
不过结合Alfred这个神器+下面这个脚本可实现热键取词。同理可将网上流传的“142000个单词语音库”解压到同一个文件夹内,借助内置的afplay命令+Alfred+下面的脚本,可做到热键取词发音。- afplay /Users/qunwang6/Sound/Webster/{query}.wav
复制代码
% S: z- @- o1 |* F, b' s; z2 @生词本
7 F+ Y' B( w- n: W* zBetterDictionary5 |8 g$ ]" W3 N$ j$ h
+ ^4 q( |) |/ h: |...
) \6 T2 B3 ` L( F # j% I8 t: w. h1 W# G
自己动手,丰衣足食。先发颗种子。) k+ B; W$ @* [) D
t6 F/ I, e5 l6 ^
" U! o) S$ Q0 w( b, B6 w
链接: http://pan.baidu.com/s/1i3rgl7n 密码: vcpf
8 z+ W2 ]) u5 g" n |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?免费注册
x
评分
-
1
查看全部评分
-
本帖被以下淘专辑推荐:
- · REFIDX|主题: 90, 订阅: 34
- · 工具|主题: 61, 订阅: 28
- · 词典制作|主题: 111, 订阅: 24
|