あしあと

自分自身のログ(足跡)となります。ソフトウェアエンジニアです。ブログはテック系の内容が少し多めです。

Pythonのimport先に飛ぶVimプラグインを作成した

タイトルそのままですが、VimPythonのimport文に記載したモジュールにジャンプするプラグインを書きました。
こんな感じで動きます。

https://raw.githubusercontent.com/pyohei/vim-python-jumping/master/demo/demo.gif

(3年くらい前に書いて放置していたので作りきりました)

インストール方法

リポジトリ

github.com

で、pyohei/vim-python-jumping の設定をお好みのvimプラグインに記載してもらえれば使えます。

使い方

import文の上で :PyImportと打てば、対象のファイルに飛びます。
キーマップはお好みのキーマップを指定すれば便利です。
(私はキーマップは設定しない組なので)

仕組・制約

仕組みとしては、PYTHONPATHのパス + 現在のファイルのディレクトリから探します。
なので、実行環境にPYTHONPATHを通しておく必要があります。
そのため、init.pyなどでインポートしている系のモジュールもうまく読め込めない事はありますが...

作った背景

Pythonvimプラグインでシンプルにこの機能を実現するツールが当時はなかったので作りました。
(今あるかは調べれていないですが...)
まぁ、かなりマニア向けなので、興味のある人はぜひどうぞ。

シンプルな画像サーバを作った(Python)

画像一覧をブラウザで見たかったので、Pythonで簡易的なサーバーを書きました。
(実際には数年前に作って放置してたものを作り上げた感じですが)
Pythonで動かす必要があるので、主にエンジニア向けですかね。
 

サンプル

実際には以下のように確認できます。
一覧画面はこんな感じ(写真は著作権フリーのものを利用しています)。

f:id:pyo_hei:20180628070911p:plain

画像を押すと、以下の様にみれます

f:id:pyo_hei:20180628070928p:plain

使い方

インストール

ソースコードはgitで取得可能です。

git cloen https://github.com/pyohei/simple-image-server
cd simple-image-server

pyramidなどの依存ライブラリがあるので、virtualenvを入れることをオススメします。
Python3.6なら、

python -m venv venv
source venv/bin/activate

で仮想環境を作る事が可能です(この手順はスキップしても問題ありません)。

環境が作れたら依存ライブラリをインストールします。

pip install -r requirements.txt

以上で環境の設定は終了です。

起動方法

あとは、画像フォルダがあるディレクトリを指定して実行すればOKです
xxxxの箇所に画像フォルダを指定してください。
(ちなみにsampleディレクトリも用意しているので、簡単に試したい人はどうぞ。)

python server/main.py xxxx

アクセス方法

デフォルトでは http://localhost:8999/login にアクセスするとログイン画面が表示します。
User: user, Password: password でデフォルトはログイン可能です。

ログインするとサンプルに載せた様な一覧画面を見る事ができます。

その他

  • 指定したディレクトリ配下の画像を再帰的に探索しているので、ディレクトリの構成は気にする必要はありません
  • 個人向けに簡易作成したものなので、バグとか要望があればどうぞ
  • リポジトリは以下です

github.com

今ひとつノート型ホワイトボードが自分に向かなかった理由

ノート型ホワイトボード(例えばバタフライボード)を、いくつか試したのですが、今ひとつ合わなかったので、その理由でも書いてみます。

対象読者

  • ノート型ホワイトボードを今後利用したいと検討している人
  • ノート型ホワイトボードを使っているが、しっくりきてない人

自分自身の使用歴史

  • 自作ホワイトボード(気が向いたら作り方書きます)
  • ダイソーのノート型ホワイトボード
  • バタフライボード

などを試した結果です。

なぜ使おうと思ったのか?

使う事で生産性が上がるのではないかと考えたためです。

なぜ、合わなかったのか?

理由はいくつかあるのですが、

  • ホワイトボードマーカーの管理が面倒
    • 蓋を開けっぱなしにしていると、枯れてしまったり
    • ペン先が潰れてくる
    • 物理ノートも使っていると、ペンの切り替えが面倒
  • ペン先が潰れるので、カジュアルに書くことをためらってしまう
  • 時間が経つ(1週間とか)と、消すのが結構大変
  • ページが足りなくなると強制的に消す必要がある
  • (定性的だが)生産性に寄与しないと感じた

と、こんな感じです。

メリットはなかったのか?

そんなことはなく、メリット自体は何個かあり、

  • 書いている途中に間違えると軽く消す事ができる
  • ノートとは異なり、意識的に消す必要があるので、見返す機会が必ず発生する
  • 複数人で考えたりするときには便利
  • (バタフライボードについては)マグネット式で固定しておく事ができる

など、目的に合わせて利用するなら、便利なツールです。

今はどうしているか?

まだ、自分の中でもベストな回答はないのですが、

  • 物理ノート … 一時的に書いたり、考えたりしたい場合
  • 物理付箋 … 忘れないようにすること(一時的)を残すため
  • Todoアプリ(Todoist) … 自分のやることの管理

を使っていて、物理ノートに書いたことを保存したい場合は、dropboxなどを使って、ドキュメントにしている感じです。
今の所、使い勝手としては気にはなっていないです。

最後に

色々書きましたが、気になっている人は試してみるのが一番です。
多分バタフライボードは新しいのが出たら書いますが:)
ちなみに、最近はノートの代わりにエバーラストも試しているのですが、その使い勝手はまた機会があれば。

(2018/05)今聴いているエンジニア系ポッドキャスト

ITエンジニア系のポッドキャストをよく聴いているので、ご紹介。
一人では得られない知識も多くあるので、エンジニアの方はオススメです。
今回の内容は、どちらかというと、自分向けのメモに近いです。

Rebuilfm

rebuild.fm

エンジニアの方なら、ご存知の方が多い、Rebuilfm。
自分自身がポッドキャストにハマるきっかけの一つは、これでした。
技術的な内容や、社会的な事、アニメ、プロダクティビティーなど、ゲストによって、様々な話をされます。
IT系のエンジニアで、ポッドキャスト聞いてみたい人は、まずRebuildfmを聞いてみるのがオススメです。
自分が好きなゲストさんが見つかるはず!

のぼりーさんのクラウドインフラPodcast

cloudinfra.audio

インフラ周り(特にクラウド系)の話が多いです。   普段、がっつりインフラを触ってないので、インフラの技術を聞けるので、重宝しています。
ゲストの方の使っているツールの紹介などもあり、普段の自分のツールへの参考になります。

mosaic.fm

mozaic.fm

フロント系の動向について説明しているPodcast
各ブラウザの動向など、詳しく説明してくださるので、サーバサイドのエンジニアの自分にとっては知らないことを知れる機会なので、重宝して聞いています。
ゲストと特定の話題について話す回もあります。

Turing Complete FM

turingcomplete.fm

システムプログラミング周りについて話すPodcast。低レイヤーの話が多いです。
メインのRuiさんとゲストの方のレベルが高すぎて、回によっては日本語をしゃべっている事以外分からないことも。
でも、その分からなさも面白さで、聞いている途中に調べならがら聞く事が多いです。
個人的には、言語処理系の話は興味深く、楽しく聞いています。

Misreading Chat

misreading.chat

読んできた、論文を紹介するPodcast
機械学習系の話も多く、初心者にもわかるように説明してくださるので、知識の強化に役立っています。
ですが、こちらも内容によってはチンプンカンプンな時も。
文献ベースで話すので、後で軽く見たりできるので、そこは助かります。

backspace.fm

backspace.fm

ガジェットの紹介など。スポットで聞いています。

Changelog

changelog.com

こちらは英語のポッドキャストオープンソースのプロダクトについて話している事が多い印象。  
日本ではあまり聞かないツールの話もあるので、興味のあるものをスポットで聞いています。

ざっと書いたので、時間があれば、好きな回とかも書きます。 この辺の話は、好きな人も多そうなので、他にオススメがあれば教えてください。

マキタの掃除機レビュー(マキタの107)

最近、マキタの掃除機を購入し、利用しているので、簡単にレビューします。
コードレス掃除機は初めてなので、比較にはならないですが。。

どんな人に読んでもらいたいか

  • 比較的安価なコードレス掃除機が欲しい
  • マキタの掃除機の購入検討している

買った商品

買ったのはこれです(「マキタの107」の方)。オプションパーツは購入していない状態でのレビューになります。

率直な感想

率直な感想としては、買ってよかったです。理由は、

  • すごく軽く、ちょっと使いたいときにサクッと使える
  • 適当な所に立てかけて置ける(引っ掛けるところがあれば)
  • 安い(購入時は税込で13480円)

吸引力は業務用に使われていることもあり、フローリングだと問題なく感じています。

デメリット

今気づいた分としては、

  • 充電するときはバッテリーを外して充電する必要があり、充電する機会が少し大きい
  • ホースの接続が若干チープ感があり、ホースの向きを変えるのが少し手間
  • バッテリーが10分程度しか持たないので、広い部屋家には不向き
  • 手の届かない細い隙間を掃除するのが難しい(オプションで買う必要あり?)
  • カラーバリエーションがない

ですが、個人的にあまり気にはなっていません。

どんな人に向いているか

  • コードレスが手っ取り早く欲しい
  • 家はそれほど広くなく(2LDKより狭い)、掃除に時間(コスト)をかけたくない
  • 掃除機のサブとして利用

全体的に満足しているので、購入を検討している人がいて、条件が一致するのなら購入することはオススメですよー。

はてなブックマークから自分の好きそうなURLを抽出するスクリプトを書いた(Python)

こんなスクリプトを書きました。(結構前にですが。。)

  • 自分のはてなブックマークを抽出
  • そのブックマークしているユーザーの一覧を取得
  • そのユーザーがブックマークしているURLを取得
  • URLを取得できた回数が多い5件を抽出し、ファイル出力

その心は?

元は、

overlap.hatenablog.jp

を読んだ時、もう少し汎用的に使えるものを作りたいと思い、作成しました。
自分と近い志向の人のブックマークから、自分向けのレコメンドができるのは面白そうだなと思ったので。

使い方

詳細は、githubのREADME.md 読めばわかるようにしています。

github.com

技術的には、Pythonが使える環境があれば、大丈夫です。
データは内部にsqliteのファイルを作り、保持するような仕組みにしています。

スクリプトを実行するとレコメンドデータをrecommend.txtというファイルで出力するようにしています。

僕の使い方

僕はRaspberry Piにcronを仕込んで動かして、出力したファイルをiftttのトリガーに送り、メールを送信するようにしています。
(この辺の仕組みは、気が向いたら書きます)
ちなみにこんな感じにメール通知が1日に1回届くようにしています。

注意点&その他

ブックマークが多い人は、最初にデータを取得するの時間がかかります。
理由は、はてなAPIをのんびり叩いているので、ゆっくりペースになります。
ソースコードgithubに載せているので好きに触ってもらえれば自分風のレコメンドに変えることもできます。

Pythonのos.path.joinの仕様にちょっとハマった

Pythonでパスを結合しようと思って、こんな感じでコードを書いていたのですが、どうにも思った通りに動かない…

Python 3.6.1 (v3.6.1:69c0db5050, Mar 21 2017, 01:21:04)
[GCC 4.2.1 (Apple Inc. build 5666) (dot 3)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> from os.path import join
>>> a = 'a'
>>> b = '/b'
>>> print(join(a, b))
/b

なんでaは結合されないのだろー、と悩みました。

で、実際にPythonのos.py(厳密にはos.pathはposixpath.py)を見ると、以下のようなコードでした。 (必要な箇所のみ抜粋)

import os

def get_sep(path):
    if isinstance(path, bytes):
        return b'/'
    else:
        return '/'

def join(a, *p):
    """Join two or more pathname components, inserting '/' as needed.
    If any component is an absolute path, all previous path components
    will be discarded.  An empty last part will result in a path that
    ends with a separator."""
    a = os.fspath(a)
    sep = get_sep(a)
    path = a
    try:
        if not p:
            path[:0] + sep  #23780: Ensure compatible data type even if p is null.
        for b in map(os.fspath, p):
            if b.startswith(sep):
                path = b
            elif not path or path.endswith(sep):
                path += b
            else:
                path += sep + b
    except (TypeError, AttributeError, BytesWarning):
        genericpath._check_arg_types('join', a, *p)
        raise
    return path

細かく読むと if b.startswith(sep)で、セパレータ(posixでは/)で始まっていると先頭は無視する模様…. 確かにdocstringにも書いているが、この仕様はなんなのだろうか...

ちなみにPythonのドキュメントにもちゃんと書いていましたね。

11.2. os.path — 共通のパス名操作 — Python 3.6.5 ドキュメント

そして、Pythonをもう数年書いているのに知らない自分もちょっと情けないですが...