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
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
ITO Akihiro
September 30, 2020
Technology
0
32
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
kintone + ローカルLLM = ?
akit37
0
140
【NoMapsTECH 2025】AI Edge Computing Workshop
akit37
0
630
【NoMapsTECH 2025】AI Tech Community Talk
akit37
0
290
エンジニア目線でのテスラ
akit37
0
72
「重鎮問題」について(軽めに)
akit37
0
78
Software + Hardware = Fun++
akit37
0
51
基本的に "リモートしかない" ワーク/20231128_KBS_LT
akit37
1
36
3つの先端技術が コミュニティ軸で融合した話。/20230615_CMCMeetup
akit37
0
34
Bootleg_越境してみたときのアウェイ感。/20230328_CMCMeetup
akit37
0
43
Other Decks in Technology
See All in Technology
複数クラスタ運用と検索の高度化:ビズリーチにおけるElastic活用事例 / ElasticON Tokyo2026
visional_engineering_and_design
0
160
AI実装による「レビューボトルネック」を解消する仕様駆動開発(SDD)/ ai-sdd-review-bottleneck
rakus_dev
0
140
JAWS Days 2026 楽しく学ぼう! 認証認可 入門/20260307-jaws-days-novice-lane-auth
opelab
11
2.3k
AWS CDK「読めるけど書けない」を脱却するファーストステップ
smt7174
3
140
JAWS FESTA 2025でリリースしたほぼリアルタイム文字起こし/翻訳機能の構成について
naoki8408
1
580
ソフトバンク流!プラットフォームエンジニアリング実現へのアプローチ
sbtechnight
0
140
非情報系研究者へ送る Transformer入門
rishiyama
11
7.6k
クラウド × シリコンの Mashup - AWS チップ開発で広がる AI 基盤の選択肢
htokoyo
2
260
[JAWSDAYS2026][D8]その起票、愛が足りてますか?AWSサポートを味方につける、技術的「ラブレター」の書き方
hirosys_
3
190
Oracle Cloud Infrastructure IaaS 新機能アップデート 2025/12 - 2026/2
oracle4engineer
PRO
0
150
組織全体で実現する標準監視設計
yuobayashi
3
490
猫でもわかるKiro CLI(AI 駆動開発への道編)
kentapapa
0
220
Featured
See All Featured
The Pragmatic Product Professional
lauravandoore
37
7.2k
The Success of Rails: Ensuring Growth for the Next 100 Years
eileencodes
47
8k
Abbi's Birthday
coloredviolet
2
5.4k
[SF Ruby Conf 2025] Rails X
palkan
2
830
Into the Great Unknown - MozCon
thekraken
40
2.3k
Navigating Algorithm Shifts & AI Overviews - #SMXNext
aleyda
1
1.2k
Darren the Foodie - Storyboard
khoart
PRO
3
2.9k
The Illustrated Guide to Node.js - THAT Conference 2024
reverentgeek
1
310
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
34
2.7k
Impact Scores and Hybrid Strategies: The future of link building
tamaranovitovic
0
230
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
360
30k
コードの90%をAIが書く世界で何が待っているのか / What awaits us in a world where 90% of the code is written by AI
rkaga
60
42k
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号