背景
Linuxコマンドを用いて例えばCPU温度などを定期的にDBに追加しています。
この時にコードをなるべく少なくしようとコマンドだけで色々と調べたのですがなかなか難易度が高かったので作成しました。
仕様
汎用的に利用できるようにしたいのでpythonのFormatのような動きを実現させたい。
コード
こうなりました。
import sys;
print(sys.argv[1].format(*sys.argv[2].split(" ")) )
- 第一引数:Formatの指定文字列
- 第二引数:空白で区切られたFormatに入れる文字列
利用方法
mosquitto_sub -t "#" -v |xargs -I@ python3 /home/hashito/command/text2format.py "insert into mqtt.msg (t,m,tm)values(\'{}\',\'{}\',UNIX_TIMESTAMP(NOW()))" @ | xargs -I@ mysql -e "@"
mqttの内容を雑にマリアDBにつっこめます
追記
@shiracamus 様からコメントいただきました。
コマンドのみだと下記の形で出来るようです。
$ echo "a b" | xargs echo | xargs printf "insert into mqtt.msg (t,m,tm)values('%s','%s',UNIX_TIMESTAMP(NOW()))"
insert into mqtt.msg (t,m,tm)values('a','b',UNIX_TIMESTAMP(NOW()))
これをずっと探していたのですが、自分の知識がなく助かりました!
ありがとうございました!