Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
xonsh oneliner
Search
ravicot
May 11, 2019
Technology
0
240
xonsh oneliner
xonsh使ったらpythonでonelinerが使いやすくなった話
ravicot
May 11, 2019
Tweet
Share
Other Decks in Technology
See All in Technology
OAuthからOIDCへ ― 認可の仕組みが認証に拡張されるまで
yamatai1212
0
130
能登半島災害現場エンジニアクロストーク 【JAWS FESTA 2025 in 金沢】
ditccsugii
0
880
ガバメントクラウド(AWS)へのデータ移行戦略の立て方【虎の巻】 / 20251011 Mitsutosi Matsuo
shift_evolve
PRO
2
200
LLMプロダクトの信頼性を上げるには?LLM Observabilityによる、対話型音声AIアプリケーションの安定運用
ivry_presentationmaterials
0
270
それでも私が品質保証プロセスを作り続ける理由 #テストラジオ / Why I still continue to create QA process
pineapplecandy
0
120
RDS の負荷が高い場合に AWS で取りうる具体策 N 連発/a-series-of-specific-countermeasures-available-on-aws-when-rds-is-under-high-load
emiki
4
3.6k
ガバメントクラウドの概要と自治体事例(名古屋市)
techniczna
3
240
ビズリーチ求職者検索におけるPLMとLLMの活用 / Search Engineering MEET UP_2-1
visional_engineering_and_design
1
140
Contract One Engineering Unit 紹介資料
sansan33
PRO
0
8.8k
Digitization部 紹介資料
sansan33
PRO
1
5.6k
Wasmのエコシステムを使った ツール作成方法
askua
0
200
ニッポンの人に知ってもらいたいGISスポット
sakaik
0
150
Featured
See All Featured
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
26
3.1k
Designing Experiences People Love
moore
142
24k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
115
20k
The Power of CSS Pseudo Elements
geoffreycrofte
79
6k
We Have a Design System, Now What?
morganepeng
53
7.8k
YesSQL, Process and Tooling at Scale
rocio
173
14k
Stop Working from a Prison Cell
hatefulcrawdad
271
21k
[RailsConf 2023] Rails as a piece of cake
palkan
57
5.9k
XXLCSS - How to scale CSS and keep your sanity
sugarenia
248
1.3M
Building Flexible Design Systems
yeseniaperezcruz
329
39k
Dealing with People You Can't Stand - Big Design 2015
cassininazir
367
27k
How GitHub (no longer) Works
holman
315
140k
Transcript
ONE-LINER.PY PYCON MINI SAPPORO 2019 @RAVICOT
whoami インフラ系 技術職 @ravicot ravicot 仮想化技術(openvz, Xen, KVM), ネットワーク設計, セキュリティ製品、ストレージ製品
メール(Postfix), データベース(MySQL)…etc…etc… 年に数回しかプログラムを書かない
何しに来たの? シェル芸? シェル芸いいよ! シェル芸楽しい! Pyhton使ってもっと楽したい!! シェルじゃなくてもいい!
XNOSH で加速しよう!! ONE-LINER.PY こ ん しゅ
None
役に立つの? あらゆる調査・計算・テキスト処理をコマンドを 一撃で終わらせる
どんなときに役に立つの? 学生には、まったりコードを書けないことがある 論文用の統計データだしておいてね 午後までに きょーじゅ
どんなときに役に立つの? どお?できた? 学生には、まったりコードを書けないことがある きょーじゅ
不整合? killall httpd 報告書つくらなきゃ 今やってるから! どうなってるの? 祭りだ わっしょい プロセス生きてる? どんなときに役に立つの?
エンジニアには、ゆっくりコードを書けないことがある ああ、障害だ 頼むだれか電話対応 影響範囲は? どのログからみる? 早く復旧してね 復旧まだー? 復旧優先? 原因特定優先? DDoS?
一 撃 必 殺 ss -ntu |grep '^¥(t¥|u¥)'|awk '{print $5,$6}'
|sed 's/:[^ ]¥+//' |sort|uniq -c|sort -nr|head -n 5 SYN flood攻撃を60秒で撃退したい!!!
Netid State Recv-Q Send-Q Local Address:Port Peer Address:Port tcp ESTAB
0 40 163.49.61.XXX:22 36.11.225.XXX:32877 tcp FIN-WAIT-2 0 0 163.49.61.XXX:443 218.218.98.XXX:50578 tcp FIN-WAIT-2 0 0 163.49.61.XXX:443 218.218.98.XXX:50581 tcp FIN-WAIT-2 0 0 163.49.61.XXX:443 210.20.229.XXX:53970 tcp FIN-WAIT-2 0 0 163.49.61.XXX:443 210.20.229.XXX:53969 tcp FIN-WAIT-2 0 0 163.49.61.XXX:443 218.218.98.XXX:50579 tcp FIN-WAIT-2 0 0 163.49.61.XXX:443 210.20.229.XXX:53965 tcp FIN-WAIT-2 0 0 163.49.61.XXX:443 218.218.98.XXX:50580 tcp FIN-WAIT-2 0 0 163.49.61.XXX:443 218.218.98.XXX:50582 tcp FIN-WAIT-2 0 0 163.49.61.XXX:443 210.20.229.XXX:53964 tcp FIN-WAIT-2 0 0 163.49.61.XXX:443 210.20.229.XXX:53967 tcp FIN-WAIT-2 0 0 163.49.61.XXX:443 210.20.229.XXX:53968 tcp FIN-WAIT-2 0 0 163.49.61.XXX:443 210.20.229.XXX:53966 tcp FIN-WAIT-2 0 0 163.49.61.XXX:443 210.20.229.XXX:53971 一 撃 必 殺
# 標準偏差 awk '{d[NR]=$1;avg+=$1} END{a=avg/NR;for(i in d)s+=(d[i]-a)^2;print sqrt(s/(NR-1))}' datafile awk
'{d[NR]=$1;avg+=$1} END{a=avg/NR;for(i in d)s+=(d[i]-a)^2;print s/(NR-1)}' datafile #分散 一 撃 必 殺 教授からの宿題を120秒で撃退したい!!! [datafile] 12 15 21 16 ・ ・ ・
速さは強さ つまり何がいいたいの?
AWK VS PYTHON 相関係数を求める awk '{dx[NR]=$1;dy[NR]=$2;avg_x+=$1;avg_y+=$2} END{ax=avg_x/NR;ay=avg_y/NR; for(i=1;i<=NR;i++){s+=(dx[i]-ax)*(dy[i]-ay); sx+=(dx[i]-ax)^2;sy+=(dy[i]-ay)^2}; print
s/(NR-1)/sqrt((sx/(NR-1))*(sy/(NR-1)))}' datafile ピアソンの積率相関係数 python3 -c "import scipy.stats as st; import pandas; df=pandas.read_csv('datafile',header=None); print(st.pearsonr(df.iloc[0],df.iloc[1]))" python WIN [datafile] 12 33 15 19 21 25 16 36 ・ ・ ・ ・ ・ ・
速さは強さ awkよりもPythonのほうが圧倒的に楽?
AWK VS PYTHON ファイルの2行目以降だけ扱いたい awk 'FNR > 1{ print $1
}' datafile python3 -c "import pandas; print(pandas.read_csv(‘datafile', skiprows=1))" awk WIN
AWK VS PYTHON 後ろから2番目の列を出力する echo "a b c d e"
| python3 -c "print(list(input().split(' '))[-2])" echo "a b c d e" | awk '{print $(NF - 1)}' awk WIN
AWK VS PYTHON パターンマッチに変数を使用する awk -v 'str=RAVI' 'match($0, str){print $0}’
datafile python3 -c "data=open('test.csv').readlines(); print([line for line in data if ‘RAVI' in line])" awk WIN
加速したい あと楽したい PYTHONで
https://github.com/xonsh/pycon2016 こ ん しゅ
Pythonic + UNIX哲学 XONSH (僕の所感)
PYTHON VS XONSH 相関係数を求める ピアソンの積率相関係数 df=pd.read_csv('datafile',header=None); print(st.pearsonr(df.iloc[0],df.iloc[1])) XONSHですっきり python3 -c
"import scipy.stats as st; import pandas; df=pandas.read_csv('datafile',header=None); print(st.pearsonr(df.iloc[0],df.iloc[1]))"
PYTHON VS XONSH ファイルの2行目以降だけ扱いたい print(pd.read_csv('datafile', skiprows=1)) python3 -c "import pandas;
print(pandas.read_csv('datafile', skiprows=1))" XONSHですっきり
PYTHON VS XONSH 後ろから2番目の列を出力する echo "a b c d e"
| print(list(input().split(' '))[-2]) echo "a b c d e" | python3 -c "print(list(input().split(' '))[-2])" XONSHですっきり
速さは強さ XONSHでONE-LINERが加速 豊富なライブラリをshell感覚で使える
インストールは5分で終わる(CentOS7.5) # yum install epel-release # yum install python36 python36-pip
# pip3 install xonsh # xonsh Welcome to the xonsh shell (0.9.0) ~ The only shell that is also a shell ~
起動してみた # xonsh Welcome to the xonsh shell (0.9.0) ~
The x-on shell ~ # echo $SHELL /bin/bash # env | grep -i xonsh XONSH_VERSION=0.9.0 _=/usr/local/bin/xonsh XONSHRC=/etc/xonshrc:/root/.config/xonsh/rc.xsh:/root/.xonshrc XONSH_LOGIN=1 XONSH_INTERACTIVE=True
ShellでPythonコード補完が効く # df = pandas.read_(タブキー) pandas.read_clipboard( pandas.read_msgpack( pandas.read_csv( pandas.read_parquet( pandas.read_excel(
pandas.read_pickle( (中略) pandas.read_html( pandas.read_stata( pandas.read_json( pandas.read_table(
先人から翼を授かる Pythonでモジュールをスクリプト上で動的にロードするには importlibを使います。 ばんくしさんのblogから抜粋 https://vaaaaaanquish.hatenablog.com/entry/2017/12/26/190153 すでにONE-LINERしている人がいた…!
XNOSH で加速しよう!! ONE-LINER.PY こ ん しゅ @ravicot