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
ビジネスPythonを学ぶ会_2020_11_09_Ogu
Search
J-Ogu
December 09, 2020
Programming
0
390
ビジネスPythonを学ぶ会_2020_11_09_Ogu
J-Ogu
December 09, 2020
Tweet
Share
More Decks by J-Ogu
See All by J-Ogu
JBUG広島&JBUG岡山 #共同開催 2020_06_21 LT資料
ogu
1
410
すごい広島 With Python 発表資料_2020_0129
ogu
0
370
PyconJP2018 09_18 小栗潤一 Pythonで「お絵描きパズル」を解いてみた
ogu
0
2.7k
Pycon JP 2018 python_お絵描きパズルのロジックまとめ.pdf
ogu
1
860
Other Decks in Programming
See All in Programming
週次リリースを実現するための グローバルアプリ開発
tera_ny
1
110
テストケースの名前はどうつけるべきか?
orgachem
PRO
0
160
毎日13時間もかかるバッチ処理をたった3日で60%短縮するためにやったこと
sho_ssk_
1
400
非ブラウザランタイムとWeb標準 / Non-Browser Runtimes and Web Standards
petamoriken
0
310
命名をリントする
chiroruxx
1
460
Zoneless Testing
rainerhahnekamp
0
120
Go の GC の不得意な部分を克服したい
taiyow
3
860
rails stats で紐解く ANDPAD のイマを支える技術たち
andpad
1
300
ChatGPT とつくる PHP で OS 実装
memory1994
PRO
2
130
これでLambdaが不要に?!Step FunctionsのJSONata対応について
iwatatomoya
2
3.8k
iOS開発におけるCopilot For XcodeとCode Completion / copilot for xcode
fuyan777
1
270
PHPで作るWebSocketサーバー ~リアクティブなアプリケーションを知るために~ / WebSocket Server in PHP - To know reactive applications
seike460
PRO
2
670
Featured
See All Featured
How GitHub (no longer) Works
holman
311
140k
The Power of CSS Pseudo Elements
geoffreycrofte
73
5.4k
Building an army of robots
kneath
302
44k
Product Roadmaps are Hard
iamctodd
PRO
50
11k
Rails Girls Zürich Keynote
gr2m
94
13k
Git: the NoSQL Database
bkeepers
PRO
427
64k
Designing for Performance
lara
604
68k
Building a Scalable Design System with Sketch
lauravandoore
460
33k
Become a Pro
speakerdeck
PRO
26
5k
The Pragmatic Product Professional
lauravandoore
32
6.3k
Cheating the UX When There Is Nothing More to Optimize - PixelPioneers
stephaniewalter
280
13k
Practical Tips for Bootstrapping Information Extraction Pipelines
honnibal
PRO
10
810
Transcript
jupyter notebook ipywidgets を使用してお絵かきパズルを 可視化してみた ビジネスPythonを学ぶ会 2020.11.09 小栗 潤一
・小栗潤一 (おぐり じゅんいち) ・株式会社総合オリコミ社 ・ エンジニア (システム研究課 ディレクター) ・ チラシ制作の社内業務を自動化
・よく使う言語 ・JavaScript(adobe)、 AppleScript、 Python、 PHP、 Vue.js ・自分について ・ デザイナーとして入社、 独学でプログラムを始める。 ・ 独学に限界を感じて2016年に地元の 「すごい広島」 という勉強会に参加 ・ 趣味は、 数独・お絵かきロジックなどパズルが好き ・2018年に 「Pythonでお絵かきパズルを解いてみた」 ・ 本日の本題ではないですが仕事で行っている 「可視化」 をご紹介 自己紹介
重点課題の抽出 社内業務改善 細かなPGも含めると100~200くらい 障害発生時の対応件数 ・Excelデータから編集用データに変換 ・ 日づけ、 曜日のチェック ・ 画像データの検索
・slackでの問い合わせをスプレットシートに残している ・ 問い合わせを分析して問題点を抽出 -> 改善を行う
問い合わせが多いプログラムを抽出 重点課題の抽出 ・2020年6月から6ヶ月で約80回の問い合わせ ・Excelから編集データに変換するPGの問い合わせに焦点を当てる
問い合わせのワードから問題点を推測 重点課題の抽出 ・ 画像 ・ 確認・監視のワードが多い。 前工程の問い合わせが多いことが判明した
対応後の効果を検証 重点課題の抽出 チームで 取り組んだことを 社内に向けて 発信するために データの可視化
本日の議題
2018年 PyCon JP 「Pythonでお絵描きパズルを解いてみた」 登壇時に使用した ・jupyter notebook ・ipywidgets を使用したデータの可視化
本日の議題 ・ お絵描きパズルとは ・ データの処理について(Pandas,Numpy) ・ ロジックの一例 ・DEMO (お絵描きパズルを解く) ・
まとめ (可視化で気をつけていること)
本日扱うデータ お絵描きパズルとは
お絵描きパズルとは 本日扱うデータの説明 数字をヒントに マスを塗っていき 現れたイラストを 答えるパズルゲーム 1990年代に 流行
お絵描きパズルとは ピクロス (任天堂) お絵かきロジック (世界文化社) ののぐらむ イラストロジック 名称が違うだけで 同じルール
可視化 ・jupyter notebook ・RISE ・matplotlib、 pillow お絵描きパズルとは Pandas、 Numpyを使用して問題を解く。
白のマス 黒のマス 塗り指示 xのマス ・ 処理が未確定の空白のマス ・ □□□で表現 ・ 配列ないでは[0,
0, 0, ] ・ 処理が確定した塗り潰されたマス ・ ▪▪▪で表現 ・ 配列ないでは[1, 1, 1, ] ・ 問題の左・上辺にあるヒントの数字 お絵描きパズルとは 用語の説明 ・ 塗られないことが確定したマス ・ □□□で表現 ・ 配列ないでは[-1, -1, -1, ]
データの処理の仕方 Pandas、 Numpy 簡単な配列計算ロジック
DataFrame Numpyの配列計算 Series データについて [10] [0,0,0,0,0,0,0,0,0,0] [3,2,2] [0,0,0,0,0,0,0,0,0,0]
Jupyter Notebook ipywidgets RISE (拡張機能) ロジックで配列計算を行い解いていく Jupyter Notebookを使った開発 ・ デモ環境
本日の可視化の本質ではないので ロジックの一例を 一つだけ説明
None
None
None
DEMO
まとめ
誰に何を伝えたいのかを意識する 意識することでデータに説得力!! 目的を明確にして、 目的に合ったデータの加工、 可視化を意識する ・ 開発デバッグのための可視化 ・ 決裁者に納得していただくための可視化 データを加工する際に可読性、
スケールを意識する データは簡単に手に入る 実際のデータに触れてみて、 慣れることが大事!! 様々なことが簡単にデータ化できる 簡単に手に入れることができる ・使用履歴 ・apple watchからバイタルデータ ・ 天気 etc... うまく活用することができていない まとめ