掌上百科 - PDAWIKI

 找回密码
 免费注册

QQ登录

只需一步,快速开始

查看: 1548|回复: 10

[教程] 采用Vim+AHK快速处理图片版词典的词条索引

[复制链接]
  • TA的每日心情
    奋斗
    2019-10-13 07:34
  • 签到天数: 209 天

    [LV.7]常住居民III

    发表于 2019-2-6 12:00:04 | 显示全部楼层 |阅读模式
    本帖最后由 VimVim 于 2019-2-6 12:38 编辑
    4 I; }9 U: r8 j. ^5 _
    ! w& H+ C( }3 n, B- t, H3 F9 c4 w; A+ C8 X, r  W6 H6 ]

    6 d) j# [$ V1 T; M5 a/ F图片版词典的要点是精确校准处理的高清词典图片和精确的词条索引。图片版词典,虽然
    * y) }3 u8 V+ V$ r词条内容可以不用文本化,可以直接用图片来代替,但是用于检索的词头是必须要是文本
    4 G+ E. H' C( Y. T& P& ~& g3 j格式的。目前 OCR 可以辅助自动化处理,但 OCR 精确度有限,还需要人工检查。文字版! n0 u8 R! V! j: _5 }1 j( ?
    的要弄排版,图片版的要获取词头,各有各的难处。+ Y" l/ h* N6 A, H
    . \. z* ~) o% b
    这是我第一次制作图片词典《现代汉语词典》中关于词条索引制作的一点经验总结,供大; N6 l9 u' E! g: Q8 g
    家参考:
    . `# K- r7 Q' y( d' x1 C& o9 n( z5 T7 |& ^$ t! g
    (一)在 vim 中将页码和字头整理成如下格式:
    3 U6 W, [" c3 P' K6 i2 P% T" x! }; U$ W一行一个页码或词条,页码下面可以有多个词条,如
    ! u" f5 m: |- i2 i3 @( c" h
    & `3 N* v/ Q' X# `) b
    1. 0001
      ) E5 g# }. z6 f8 c
    2. 一  
      ' W: v' ^' {- C: r/ r
    3. 已  
      $ {) ?8 B; [% ?& u( _# u
    4. 0002
      ( B  R0 e* i- r6 b: `# B6 m; m- M
    5. 亿  
      " H+ [1 ]' y: E" o! L
    复制代码
    ) L6 `7 b, d% Q) o+ A( {8 _
    这一步的难点是如何简洁、快速、准确地录入页码及对应的词条,便利地图片翻页处理。* m* Y( ?# q7 u3 C8 {8 @
    我应用Vim + AHK进行快速处理:Vim按左右栏目自动调整窗口位置,并自动调整对应页码4 Q. _: ^7 a4 O  k5 C' l+ f
    ,以及录入、校对等词条整理工作;AHK的用途有两个:一是置顶并透明化Vim窗口,二是
    % g+ a+ ?! j% W8 |" _快速实现图片翻页。
    6 r) R1 A! Y, u6 x
    . z9 A$ G% I7 T. m: {6 `) F为了让大家更好地观摩,我录制了一小段处理过程的视频样式:
    * K2 M0 F1 e; I+ F7 RVideo:采用Vim+AHK快速处理图片版词典的词条索引; f( z! V* Z5 `: B7 |1 g0 B9 @

    3 ^! [* a2 T, k) F+ s3 @
    ( d7 u) L9 g8 Y1 \2 w; \) l3 @3 z(二)在 vim 中执行一个自定义命令将其转换为如下 mdx 源文件" n5 ]( _$ y0 h+ h

    ' Y  E; Z: n0 C, k; W  }
    1.     一
      6 M9 b. y, E  z
    2.     @@@LINK=XDHYCDTOC00018 ?* ^9 d% ?: @5 x. O
    3.     </>
      - e7 k$ e  O7 e5 q# w! J; q
    4.     已: o2 o& r* F% @; r" y
    5.     @@@LINK=XDHYCDTOC00017 y  g! a2 l, P& y8 h2 j
    6.     </>' N( p! O7 w, N$ y. O' Q' C6 r- a
    7.     亿
      ' \8 D: }" f- V
    8.     @@@LINK=XDHYCDTOC0002, ?& D! t6 K! b" ~
    9.     </>
    复制代码
    # y# }# {" c) J; H) y$ l3 O
    详见上面的demo演示
    . r5 h7 |+ V0 O5 B0 d, Y
    - V* F8 c0 s" L$ R相关帖子
    , z; G& T: i6 y6 a( V& }2 j- A' K& a$ N  i
    采用Vim快速转换图片词典的页码为mdx源文件
    + ^- q0 U( g4 c0 n. W5 k, ahttps://www.pdawiki.com/forum/forum.php?mod=viewthread&tid=32971
    ! d4 e! G; ?+ ]4 A0 l  |8 T(出处: 掌上百科 - PDAWIKI)+ G5 H' ^9 [% \

    * y4 k8 Y7 B: O  t9 \0 v
    - Q! D! u) b% O2 t  v( i* X4 k0 Q; u  Z# J, f& `4 q8 ?) H- V+ e
    : o* P$ y7 B7 v. ?3 ~; g5 z
    8 V1 }7 w6 {& V; z# U) N- Z7 z5 ~; F

    本帖子中包含更多资源

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

    x

    评分

    1

    查看全部评分

    该用户从未签到

    发表于 2019-2-6 16:36:42 | 显示全部楼层
    非常感谢你的演示和解说!
    : n  `$ B0 ]/ R- D) J/ ~我不知道该如何评价,总感觉效率还不够高... " i* V, T1 A# @
    在已经有第5版等的词条索引的基础上,增补去无, 本身就应该挺快了
  • TA的每日心情
    奋斗
    2019-10-13 07:34
  • 签到天数: 209 天

    [LV.7]常住居民III

     楼主| 发表于 2019-2-6 16:53:33 | 显示全部楼层
    本帖最后由 VimVim 于 2019-2-6 16:57 编辑
    " J2 c; M2 {! H. W5 i3 n
    chigre3 发表于 2019-2-6 16:36/ F* J; Z! P, J
    非常感谢你的演示和解说!+ g7 v6 I( Y* K; g3 a
    我不知道该如何评价,总感觉效率还不够高... + s. o& J* i# X. C9 S
    在已经有第5版等的词条索引的基础 ...

    $ U1 V% x* s6 j5 a0 t效率确实不是最高的,我的宗旨是,制作过程就是最好的学习过程。整个词典的效率瓶颈都在于词条的录入、校对,这个只能人工一条一条过才能保证质量。# J% N, U3 I7 N" L
    其他都是辅助手段,方法各异,我只是采用了自己熟悉的工具,做了适度的自动化封装,便于用在更多的字典制作上,但依然有很强的个性化,不具有推广性。
    + |& N$ U* X$ L: `8 q- M- k
  • TA的每日心情
    无聊
    2022-9-25 21:09
  • 签到天数: 1136 天

    [LV.10]以坛为家III

    发表于 2019-2-6 19:41:30 | 显示全部楼层
    请问有那些步骤是需要用到 AHK,vim script 办不到的?
  • TA的每日心情
    奋斗
    2019-10-13 07:34
  • 签到天数: 209 天

    [LV.7]常住居民III

     楼主| 发表于 2019-2-7 00:00:00 | 显示全部楼层
    本帖最后由 VimVim 于 2019-2-7 00:03 编辑
    1 @, h7 H" N+ y0 h
    oversky 发表于 2019-2-6 19:41
    " Y( F5 C9 P( w$ r请问有那些步骤是需要用到 AHK,vim script 办不到的?

    & T: t% a3 R1 R7 T& V用一个快捷键实现如下所有操作(多个指令容易出错且降低效率),其中加粗处我只知道用ahk实现,此外让Vim置顶并半透明也是用AHK:
    1 {$ {; m) F0 c1 O5 j0 e# c% v' r: d" w  x- e
    若当前为左栏,则调用调用vimscript的命令,切换至左窗口,移动光标到下一行(也就是对应的词条都写到这个新一页之下),然后切换回右窗口,调整右窗口大小,并将当前行显示到顶部;
    6 \( ~1 l7 g) z6 D2 x" \. A( p. H0 N/ ]6 F9 B
    若当前为右栏,则从vim切换到xnview,按pagedown将图片翻至下一页,然后再切换回Vim,然后调用vimscript的命令,切换至左窗口,移动光标到下一行(也就是对应的词条都写到这个新一页之下),然后切换回右窗口,调整右窗口大小,并将当前行显示到顶部,最后保存所有文件。
    & t: I4 ?$ F) p! ?
    2 ^  m, `  l: m" e# A
  • TA的每日心情
    无聊
    2022-9-25 21:09
  • 签到天数: 1136 天

    [LV.10]以坛为家III

    发表于 2019-2-7 00:04:10 | 显示全部楼层
    原来是还有用到 xnview,谢谢您的指导。
  • TA的每日心情
    奋斗
    2019-10-13 07:34
  • 签到天数: 209 天

    [LV.7]常住居民III

     楼主| 发表于 2019-2-7 00:07:36 | 显示全部楼层
    oversky 发表于 2019-2-7 00:04
    9 A' t% b8 l& }1 Y/ p+ k( L( `原来是还有用到 xnview,谢谢您的指导。

    9 a6 A9 T8 a- r; w+ r8 Z+ V. F- ?看图软件,随便挑一个都行
  • TA的每日心情
    开心
    2018-8-8 03:13
  • 签到天数: 1 天

    [LV.1]初来乍到

    发表于 2019-2-26 14:15:25 | 显示全部楼层
    本帖最后由 喬治兄 于 2019-2-26 14:19 编辑
    7 O! R6 l+ s; M2 P4 l$ Z3 z; i* {
    9 v6 ]% @  s; F; E/ ~VimVim 兄:
    + u' x' `) X0 J: L# R6 H& }& _. G請教一個排版的問題9 _1 z6 R& L  H* d
    小弟想把辭典的每頁首字和尾字置於同一列的左右兩端7 K4 I  r* o1 k2 [- J; E! m! ?5 t  B
    但因不熟 css 不知該如何達成此功能) s/ m* q" M6 B# Y
    能否給小弟指導一下,謝謝您
    & @# Y9 \5 R- W5 L

    本帖子中包含更多资源

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

    x
  • TA的每日心情
    奋斗
    2019-10-13 07:34
  • 签到天数: 209 天

    [LV.7]常住居民III

     楼主| 发表于 2019-2-26 21:19:31 | 显示全部楼层
    本帖最后由 VimVim 于 2019-2-26 21:39 编辑 " b! L$ R- g' C# q* W
    喬治兄 发表于 2019-2-26 14:153 F2 L0 b- Z3 f5 L; H- m: \3 w
    VimVim 兄:" q# f, g+ s* s' {
    請教一個排版的問題
    3 Y2 v7 @  x) j5 t小弟想把辭典的每頁首字和尾字置於同一列的左右兩端

    # G9 }. n+ ]5 j1 V+ p要的是这个效果吗?0 S2 q5 G) f4 e0 {& l
    下面的border纯粹是为了显示效果,你完全可以在css中将border设置删除。
    ) y* s3 D6 v& x
    ! N) B9 K" R1 z" S& T* m2 r, O7 T% Y% ?# [% ]* A" e' z
    HTML文件:
    1. <!DOCTYPE html>- b2 k  E( T* r1 S$ M) A
    2. <html xmlns="http://www.w3.org/1999/xhtml">
      ( b7 k2 u8 ~* G
    3. <head>( D1 e; Y5 f  m$ a7 ]
    4.     <title></title>
      " C7 {- N; S3 {# {  g  w
    5. </head>  q% p, ]: \1 i
    6. <body>
      * M# u8 Y0 o3 Z
    7.     <link rel="stylesheet" type="text/css" href="test.css" />: `' j0 Z2 O* k8 f3 U( ]
    8.     <div class="navtext">
      + N$ U) D6 X9 @& y
    9.         <span class="left">accident</span>
      ) w  J% q" e/ {6 G/ G9 v
    10.         <span class="right">accumulate</span>& d4 B7 E, L; w
    11.     </div>
      ' u" j4 N3 _7 {- t5 }8 h9 M% `
    12.     <div class="mainbodyimg"><img src="test.png" /></div>5 |- t# _9 v  V/ ^: f; N
    13. </body>6 B- R5 v  Q2 S* a' E: V
    14. </html>5 B$ ?$ j! i) Q! v
    复制代码
    + i1 h3 E! ^9 a2 q9 x" c) q
    4 m) [( r8 Y5 [* q& e/ q/ L4 @6 k
    6 g' ^# d3 v1 m8 T& O: s7 c# b
    CSS文件:! |. z, w7 F+ K; S/ P, u
    原理:
    3 K% P* Q3 G$ j6 ]- t- p) r7 U5 M1、设置两个span,其宽度及padding合计为图片宽度,并设置每个span中的文本分别左右对齐;7 a* j. b& w2 `
    2、将两个span都float left,这样左右两个span就会按顺序排列;
    * n3 _: e( X2 ^, ~8 ]6 G! {$ P0 k9 T5 K' T( d
    1. /*左对齐*/" {! Z5 Z8 ]3 M$ U; L1 S
    2. .navtext .left {1 O7 m! M' Z6 E3 A; Z# H
    3.     float: left;
      , v( n8 ~8 o  n8 N7 a- J" f' T
    4.     text-align: left;
      - Y" ^) t" _$ m' }$ `8 }" F. k# ^7 i
    5.     padding: 0 0 0 2em;
      . ?% B4 P8 b. W; H
    6.     width: 18em;" \+ Q9 ]- y! P8 }
    7.     border: 1px dotted black;4 W6 y6 Q+ M' [& k( O
    8. }. Q5 i6 H: ~, v# h  B: U* \- T) w
    9. /*右对齐*/
      1 r& w9 x1 H1 D
    10. .navtext .right {6 `+ i6 u5 C! I7 s6 f( m) z
    11.     float: left;
      1 v" J( v) c) z/ l
    12.     text-align: right;5 D6 _; H" k) ]) j/ v- I5 f& ^% a
    13.     padding: 0 2em 0 0;" u0 d  ?* S, z8 P$ {
    14.     width: 18em;, t) x, _7 ]6 W3 ?0 x: [3 u8 o+ g
    15.     border: 1px dotted black;* }3 y; S. T7 D
    16. }! _: h. J! Q2 U/ B
    17. /*图片*/
      " n9 V6 F- I4 U3 m. T# P4 b9 ]' g
    18. .mainbodyimg img { 9 \9 {5 f+ K" t, K3 J8 l1 z
    19.     width: 40em;! ], _; {/ y1 E, H% O: m6 R7 n6 h# f3 [
    20.     border: 2px dotted black;
      ' |1 W5 {8 h3 A5 h# m7 S# m
    21. }
      7 [! j4 d* @# `8 w
    复制代码
    8 v7 e) N3 z- M* \7 ^0 ^. w1 d
    您可以用附件的测试文件多试试各种参数来满足个性化需求:. M$ Y' u# l/ n
    " Z% F6 n$ c0 @1 m+ a6 s

    " Z. H  G* t7 S' v8 _2 a7 B5 V! [4 r& c# L

    本帖子中包含更多资源

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

    x
  • TA的每日心情
    开心
    2018-8-8 03:13
  • 签到天数: 1 天

    [LV.1]初来乍到

    发表于 2019-2-27 02:59:13 | 显示全部楼层
    VimVim 发表于 2019-2-26 21:19
    9 x: M9 f: {7 m要的是这个效果吗?
    ! Z. T4 |0 Y* v9 t# ?+ m7 b下面的border纯粹是为了显示效果,你完全可以在css中将border设置删除。
    / s% w! b8 R) _$ U- ?# A1 ?
    VimVim 兄:
    4 f( K) V) F* }! C9 Q* S0 u# Z" l+ u非常感謝您的指點迷津
    " k* m. }- Q3 _; Z) m" }3 ~& C9 R您連文檔都附上了
    # m  @* b% j# c9 O太感謝您了
    , U6 m' E. `/ ?7 G- k: O/ a- [; N真是太給力了
    # e: n+ R3 B3 B4 h+ ]( `/ Z6 cThanks again
    7 M6 x5 o7 v8 L) M
    + d+ n$ i6 Q, d
  • TA的每日心情
    奋斗
    2021-3-15 08:06
  • 签到天数: 585 天

    [LV.9]以坛为家II

    发表于 2019-8-12 14:25:43 | 显示全部楼层
    没太明白怎么用。
    您需要登录后才可以回帖 登录 | 免费注册

    本版积分规则

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

    GMT+8, 2024-5-15 12:38 , Processed in 0.071263 second(s), 14 queries , MemCache On.

    Powered by Discuz! X3.4

    Copyright © 2001-2023, Tencent Cloud.

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