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
CDLE LT会「お試しプログラミング forとifとfunction()」/20200930...
Search
ITO Akihiro
September 30, 2020
Technology
0
10
CDLE LT会「お試しプログラミング forとifとfunction()」/20200930_CDLE_LT
CDLE LT会#2
--
お試しプログラミング forとifとfunction()
プログラミングしたことない人向け。週末にお子さんと一緒にどうぞ。
ITO Akihiro
September 30, 2020
Tweet
Share
More Decks by ITO Akihiro
See All by ITO Akihiro
Software + Hardware = Fun++
akit37
0
12
基本的に "リモートしかない" ワーク/20231128_KBS_LT
akit37
0
11
3つの先端技術が コミュニティ軸で融合した話。/20230615_CMCMeetup
akit37
0
9
Bootleg_越境してみたときのアウェイ感。/20230328_CMCMeetup
akit37
0
19
始まりは2017年のG検定。/20221026_AITable
akit37
0
10
kintone知能化計画/20220902_kintone_and_JPStripes
akit37
0
18
外観検査用画像前処理の_コツをコード解説付きで。/20220810_CDLE_LT
akit37
0
10
サブスク課金に銀行振込を追加してみた。その①/20220713_JPStripes
akit37
0
14
AI、何から始めたらいい?/20200205_AIMeetup
akit37
0
7
Other Decks in Technology
See All in Technology
安心してください、日本語使えますよ―Ubuntu日本語Remix提供休止に寄せて― 2024-11-17
nobutomurata
1
990
個人でもIAM Identity Centerを使おう!(アクセス管理編)
ryder472
3
200
SREが投資するAIOps ~ペアーズにおけるLLM for Developerへの取り組み~
takumiogawa
1
210
強いチームと開発生産性
onk
PRO
34
11k
インフラとバックエンドとフロントエンドをくまなく調べて遅いアプリを早くした件
tubone24
1
430
隣接領域をBeyondするFinatextのエンジニア組織設計 / beyond-engineering-areas
stajima
1
270
iOS/Androidで同じUI体験をネ イティブで作成する際に気をつ けたい落とし穴
fumiyasac0921
1
110
信頼性に挑む中で拡張できる・得られる1人のスキルセットとは?
ken5scal
2
530
Lambdaと地方とコミュニティ
miu_crescent
2
370
Terraform CI/CD パイプラインにおける AWS CodeCommit の代替手段
hiyanger
1
240
OCI 運用監視サービス 概要
oracle4engineer
PRO
0
4.8k
ノーコードデータ分析ツールで体験する時系列データ分析超入門
negi111111
0
410
Featured
See All Featured
How to Think Like a Performance Engineer
csswizardry
20
1.1k
What's new in Ruby 2.0
geeforr
343
31k
BBQ
matthewcrist
85
9.3k
Product Roadmaps are Hard
iamctodd
PRO
49
11k
Into the Great Unknown - MozCon
thekraken
32
1.5k
The Language of Interfaces
destraynor
154
24k
YesSQL, Process and Tooling at Scale
rocio
169
14k
Understanding Cognitive Biases in Performance Measurement
bluesmoon
26
1.4k
Put a Button on it: Removing Barriers to Going Fast.
kastner
59
3.5k
The Cult of Friendly URLs
andyhume
78
6k
The World Runs on Bad Software
bkeepers
PRO
65
11k
Designing for Performance
lara
604
68k
Transcript
お試しプログラミング forとifとfunction() ~2020.9.30 CDLE LT会#2~ connectome.design ltd. / Akihiro ITO
プログラミングしたことない人向けです • “世界のナベアツ”を実装してみます。 • Google Apps Script を使います。 • Python
での実装例も。
仕様 • 1から順に数字を表示します。 • 3の倍数、もしくは3を含む数字の場合には、数字の後ろに、” AHO” を付加します。
Google Apps Script の準備 1. Google Driveにアクセスします。 2. Google Spreadsheetを新規作成します。
3. [ツール]→[スクリプトエディタ]を開きます。 4. スクリプトを書く準備ができました。
最初に必ず試すやつ 基本的な動作環境が整っていることを確認するた めに、まずは最初に最小のお約束プログラムを動 かします。 HelloWorld() function helloWorld() { var message
= "Hello World!"; var ui = SpreadsheetApp.getUi(); ui.alert(message); }
Hello World! の実装と実行 1. スクリプトエディタにコードを書きます。 2. プロジェクト名をつけて保存します。 3. 実行します。 4.
Spreadsheetのタブに、メッセージが出力さ れます。
“世界のナベアツ”の実装/Step.1 1. 1から10まで繰り返し処理します。 2. 数字を出力します。 3. そのとき、3の倍数なら、” AHO”を付加しま す。 function
nabeatu() { var ui = SpreadsheetApp.getUi(); for(var i=0; i<10; i++) { var num = i+1; if (num % 3 == 0) { ui.alert(num + " AHO"); } else { ui.alert(num); } } }
“世界のナベアツ”の実装/Step.2 1. 1から10まで繰り返し処理します。 2. 数字を出力します。 3. そのとき、3の倍数なら、” AHO”を付加しま す。 4.
もしくは、3を含む数字なら、” AHO”を付加し ます。 // 3を含むか判定 var j = num; var flag = false; while(j > 0) { k = parseInt(j / 10); if(j - k * 10 == 3) { flag = true; break; } j = k; } if(flag) { ui.alert(num + " AHO"); }
“世界のナベアツ”の実装/Step.3 function nabeatu() { var ui = SpreadsheetApp.getUi(); for(var i=0;
i<10; i++) { var num = i+1; var j = num; var flag = false; while(j > 0) { k = parseInt(j / 10); if(j - k * 10 == 3) { flag = true; break; } j = k; } if(flag) { ui.alert(num + " AHO"); } else if (num % 3 == 0) { ui.alert(num + " AHO"); } else { ui.alert(num); } } } ※全部繋いだだけです。このまま動くはず。
“世界のナベアツ”の実装/Step.4-1 function nabeatu() { var start = 1; var end
= 100; var output = ""; var ui = SpreadsheetApp.getUi(); for(var i = start; i < end+1; i++) { output += i; if(isAho(i)) { output += " AHO"; } output += "\n"; } ui.alert(output); } 初期値化 まとめて出力 関数化 ここから、もっとそれらしく整形します。 • 初期値を指定できるように。 • 始めと終わりの数字を直感的に指定できる ように修正。 • 出力を一回にまとめる。 • 判定部分を関数にまとめて外出し。 • さらに複雑な判定部分は別関数に。 結果、メイン関数はこれだけになりました。 サブ関数は次ページ。
“世界のナベアツ”の実装/Step.4-2 function isAho(number) { var flag = false; if(number %
3 == 0) { flag = true; } else { flag = isIncludeThree(number); } return (flag); } function isIncludeThree(number) { var i = number; var flag = false; while(i > 0) { j = parseInt(i / 10); if(i - j * 10 == 3) { flag = true; break; } i = j; } return(flag); } 3で割り切れるかを判定する。 3を含むかの結果も評価して返す。 3を含むかどうかを判定する。
実行結果
実行結果 • 3を含むかどうかのロジックはいろいろあ るので、他のものも考えてみてください。 • 開始終了の数値をスプレッドシートに書 いた値から取得したり、結果を別シート を作って書き出したりもできるので、いろ いろアイデアを試してみてください。 •
APIリファレンスには「GASで何ができる か」がすべて書かれています。
Pythonで簡単に書くとこんな感じ for num in range(1, 1000, 1): i = num
flag = 0 while i>0: j = (int)(i / 10) if i - j*10 == 3: flag = 1 break i = j if flag == 1 or num % 3 == 0: print(str(num) + " AHO") else: print(str(num)) ※GASでも同じ行数で書けます。
自己紹介など • 伊藤明裕/Akihiro ITO • connectome.design株式会社[JDLA正会員] シニアアーキテクト • CDLEコアメンバー •
情報処理安全確保支援士 No.7287/G2017/E2018 • 前職からのAI人材育成の取り組み、G検定数学対策など https://www.slideshare.net/AkihiroIto1/ 情報処理 安全確保 支援士 第007287号