neovimに移行してしばらく経つが、denite.nvimをまともに使っていなかった。

それでウェブ上の記述を参考にしてキーマッピングなどを見直してみたところ以下のようなエラーが出る。


[denite] Traceback (most recent call last):
[denite] File "/home/user/.cache/dein/.cache/init.vim/.dein/rplugin/python3/denite/rplugin.py", line 26, in start
[denite] return ui.start(args[0], context)
[denite] File "/home/user/.cache/dein/.cache/init.vim/.dein/rplugin/python3/denite/ui/default.py", line 63, in start
[denite] self._start_sources_queue(context)
[denite] File "/home/user/.cache/dein/.cache/init.vim/.dein/rplugin/python3/denite/ui/default.py", line 144, in _start_sources_queue
[denite] self._start(context['sources_queue'][0], context)
[denite] File "/home/user/.cache/dein/.cache/init.vim/.dein/rplugin/python3/denite/ui/default.py", line 187, in _start
[denite] self._init_denite()
[denite] File "/home/user/.cache/dein/.cache/init.vim/.dein/rplugin/python3/denite/ui/default.py", line 685, in _init_denite
[denite] self._denite.on_init(self._context)
[denite] File "/home/user/.cache/dein/.cache/init.vim/.dein/rplugin/python3/denite/parent.py", line 35, in on_init
[denite] self._put('on_init', [context])
[denite] File "/home/user/.cache/dein/.cache/init.vim/.dein/rplugin/python3/denite/parent.py", line 62, in _put
[denite] return self._child.main(name, args, queue_id=None)
[denite] File "/home/user/.cache/dein/.cache/init.vim/.dein/rplugin/python3/denite/child.py", line 69, in main
[denite] self.on_init(args[0])
[denite] File "/home/user/.cache/dein/.cache/init.vim/.dein/rplugin/python3/denite/child.py", line 133, in on_init
[denite] raise NameError('Source "' + name + '" is not found.')
[denite] NameError: Source "file_old" is not found.
[denite] Please execute :messages command.

pythonのバージョンが合ってなかったりして問題が起こってるのかな?とか思いつつ前回の記事(neovimの:HealthCheck時にpython周りでエラーが出る時にやったこと » WisdomTrees)の通りdein自体のpython環境を見直したりしたのだけど、直らない。

その後、

:Denite buffer

はうごくのに

:Denite file_rec

などの場合にエラーが出ることがわかった。

このfile_recというコマンドをfile/recとすれば動くという情報を見つけたので、早速やってみると、エラーなしで動きはじめた。参照していたサイトの情報が古かったのだろう。

しかしおかしい。

最近使ったファイルが列挙されるだけで、そのファイルを開くことができない。

なんでや…/(^o^)\

と思いつつも色々検索していると、Denite.nvimの公式サイトを見つけた。

日本語で解説してるサイトがあるのでそちらを優先してみていたが、公式に書いてあるExampleの設定を導入するとあっさりと動いた。

denite.nvim/denite.txt at master · Shougo/denite.nvim · GitHub

英語ドキュメントを読むのに抵抗があっても、やはり一次資料を読むのは大事。

いい教訓になりました。

今はじつに快適に動いてくれているのでDeniteの作者のShougoさんには今日も感謝です。




neovimを使っていて、:HealthCheckを実行時、python3はOKなのにpython2はエラーが出ていた。
python3とpython2、どちらもOKじゃないと問題がないかはわからなかったが、とりあえずエラーが出ている状態というのは気持ちがいいものではないので解決した

環境:
os:Linux Ubuntu18.04LTS
python2:2.7.16
python3:3.7.2

このサーバーではpythonのバージョン管理にpyenvを使っている。

記事執筆時に新しいバージョンだったpython2とpython3を導入している
それぞれ環境のところに書いてあるpythonをpyenvを使ってインストールをした。

その後、~/.config/nvim/init.vimに下記の記述を追加


let g:python_host_prog = expand('~/.pyenv/versions/2.7.16/bin/python2')
let g:python3_host_prog = expand('~/.pyenv/versions/3.7.2/bin/python3')

これで:CheckHealthをするとエラーは消えた

バージョンを直で書くのはよくないとかいう声も聞こえてきそうだけれど、とりあえずはこれでよし

(本当の問題は別のプラグインがまともに動いてくれていなくて、これがpython2がうまく動かないことに起因しているのかを確かめたかったのです)

下記記事を参考にさせていただきました。ありがとうございます。

init.nvim にpython のpath を指定してneovim の起動速度を早くする - Qiita




巨大なデータファイルの数行に一行がほしいということがあります。

たとえば、1分おきに記録されている元データがあるけど、実際には1時間に一回のデータが見られればいいという場合、60行につき1行のデータがとれれば事足りるという具合です。


result = ""

idx = 0
File.open('./src.csv', 'r') do |f|
    f.each_slice(10000) do |chunk|
        result += chunk[0].to_s
        puts idx	#check progress
        idx += 1
    end
end

File.open("./output.csv", 'w') do |f|
    f.puts result
end

肝は io.each_slice(n)メソッドを使うことです。

もともとのsrc.csvは1億2千万行を保持するファイルですが、each_slice(10000)を使うことによって、1万件のデータをひとかたまり(chunk)として取り出し、その1行目をresultに追記していくことで1万行につき一行を取り出すということをやっています。

この方法だと、メモリの使用量も全行を読み出すのに比べてずいぶん節約できているようでした。

スクリプトを回して10秒ちょっとくらいで無事、1万2千件のデータがoutput.csvに保存されました。