注意:(´_ゝ`)が勝手に調子にのってやってるだけですので、あまり深く気にしないでください。
テキスト形式のかんな辞書ではできましたが、他の辞書ではどうやるのか知りません。
例として、とりあえずhttp://omaemona.sourceforge.net/packages/Zisyo/[1]から、2ch.tを持ってきます。注意:03/08/27に更新されていますが、最近のものでは試していません。
$ vi 2ch.t
ddコマンドでコメント行を削除し、
で整形する。viじゃなくてもいいと思う。
$ qkc -sm 2ch.t
で文字コードを合わせる。
OSASKのFDを挿入。
$ mount /mnt/floppy
$ cp /mnt/floppy/te_dict0.txt ./
$ cat te_dict0.txt 2ch.t > /mnt/floppy/te_dict0.txt
$ umount /mnt/floppy
再起動して、あとは!guide!.txtでも読んでください。
お叱り
- そういえばte_dicv0.binしたときに、error:insertとかたくさんでてたな。。。いちおう使えてますが、なんか多分間違えてます。馬鹿か?>自分 -- (´_ゝ`)[2] 2003-08-29 (金) 15:32:37
- うーん!。これはなかなか面白い試みですねぇ。私も早速試してみよう。 -- hideyosi[3] 2003-08-29 (金) 15:42:30
- そのエラーは同じ読みを検出したというエラーだと思います。心当たりはありますか? -- K[4] 2003-08-29 (金) 15:50:29
- すみません。よく意味が分かりませんでした。できた辞書は使えることしか試してないもので。。オリジナルのte_dict0.txtには「入出力」や、「防衛」の行が重複しているようですが。。 -- (´_ゝ`)[2] 2003-08-29 (金) 15:57:21
- すみません、おっしゃるとおりでした。重複はまずいのですが、それはerror:insertにはならないようです。・・・ちょっとまじめに調べてみました。そのエラーが出るのは、次のうちのどれかです。 -- K[4] 2003-08-29 (金) 16:33:41
- 1.辞書サイズが僕の想定限界に近くなりすぎた(256KB)。2.変換対象のひらがなはあるが、変換先の漢字(漢字ではなくてもいいが)がない。3.一つの読みに対して、変換候補が多すぎる(最大60)。・・・ありそうなのは容量オーバですかね。重複削ればサイズは減りますし、要望があれば上限をもっと増やすこともできます。 -- K[4] 2003-08-29 (金) 16:39:48
- 重複についてですが、例えば「あらし」が2ch.tでは次のように登録されています。 -- K[4] 2003-08-29 (金) 16:46:06
あらし 荒らし
あらし 荒ら氏
あらし 荒氏
あらし 新氏
あらし 嵐
- さらに読み「あらし」については、te_dicv0.txtにもあります。
- この結果、おそらく「あらし」を変換しても、この中のどれか一つしか変換候補に出てこないでしょう。もしこれを全部有効にしたければ、これらを一つにまとめる必要があります。
- こうすればちゃんとこの順序で候補が出てきます。この辺の処理をやってくれるフィルターを作ればいいんですが、僕には面倒で・・・。
- 将来的には読みの重複もエラーにする予定です。もっとも、それより先に用言活用対応辞書にアップグレードするかもしれませんが(その場合でも、今の辞書はそのまま利用できるようにする予定です)。 -- K[4] 2003-08-29 (金) 16:55:14
- 同じテキストファイル中で、同じ候補が縦にならんでいるのならば、Perlかなんかでちょちょっとやればすぐでは?ちなみに、現在のteditの辞書はSKKの辞書を整形したものに、川合さんが手を加えているかたちですね。 -- くーみん[5] 2003-08-29 (金) 18:49:49
in_ar = []
while instr = gets
in_ar << instr.chomp
end
in_ar.sort!
hl = ""
pt = ""
in_ar.each {|s|
if s != "" then
if /^([^\/\s]+)(\s+)(.+)/ =~ s then
key = $1
sth = $3
hl = key if hl == ""
if hl == key then
if pt == "" then
pt = sth
else
pt = pt + " " + sth
end
else
print hl + "\t" + pt + "\n"
pt = sth
hl = key
end
end
end
}
print hl + "\t" + pt + "\n" if hl != ""
適当に名前を付けて(とりあえず tdicm.rb )保存、コマンドラインで以下のように実行。ファイルに入れる場合はリダイレクトかまして。
- ↑Rubyでよければどうぞ 笑・・・だけどあまりテストしっかりしてないので・・・試してダメだったらゴメン -- nisi[6] 2003-08-31 (日) 22:37:03
- 早速へんなとこがあったので修正しました 汗 -- nisi[6] 2003-08-31 (日) 22:51:24
- 神!感謝感謝。 -- (´_ゝ`)[2] 2003-09-02 (火) 18:58:48
- ちなみに複数の辞書を結合したい場合は結合したいファイル名を列挙してください。ワイルドカード指定でもいいですにょ -- nisi[6] 2003-09-03 (水) 16:24:06