この記事を読むことで、PythonとGASでsplitメソッドを使って文字列を空白部分で分割してリスト(配列)に格納し、ループを使ってリストを出力する方法、Pythonでは通常のループ対応して、内包表記で書く方法の概要も掴めます。
また、GASでは二次元配列として取得、出力する方法の概要が掴めます。
このコーナーでは、プログラミング学習コンテンツのpaizaラーニングのレベルアップ問題集の同じ問題をPythonとGAS(Google Apps Script)で解いたコードを掲載しております。
GAS(Google Apps Script)はスプレッドシートを使ってコードを書いていおります。
Pythonではpaizaに入会しなくても問題集を解きたい方向けにpaiza.ioを用いております。paiza.ioの使い方はこちらから。
(入会するか否かは問題集を解いて見てからの読者様のご判断にお任せ致します。
どちらの選択をされても記事を読めるようになっておりますので、安心して下さい。)
3 つの文字列の半角スペース区切りでの分割 (paizaランク D 相当)
問題:
文字列He likes paizaを、半角スペースで分割して出力してください。
入力される値
なし
期待する出力
He likes paizaを半角スペースで区切り、区切られた文字列を改行区切りにして 3 行で出力してください。
また、末尾に改行を入れ、余計な文字、空行を含んではいけません。
He
likes
paiza
ではまず、Pythonで解いてみます。
■ Pythonでの解き方 ■
手順として、
1:リストarrayにsplitメソッドを使って空白で文字を区切って配列に入力
2:配列を確認
3:ループで出力
で、行います。
手順1で、文字列「He likes paiza」にsplitメソッドを使って文字を分割します。
その部分のコードです。
#splitメソッドで分割した文字列をリストarrayに代入
array='He likes paiza'.split(' ')手順2では、リストarrayに分割して文字列がそれぞれ格納したことをprint文で確認します。
array='He likes paiza'.split(' ')
#リストarrayをそのまま出力
print(array)その出力結果です。

リストarrayに格納されたことが確認できたので、arrayをループで出力します。
そのコードと出力結果です。
arrayの中の文字をwordに格納してループが終了するまで出力しています。
array='He likes paiza'.split(' ')
print(array)
#リストarrayをループで改行して出力する
for word in array:
print(word)
このループの所を内包表記で記述したコードです。
array='He likes paiza'.split(' ')
print(array)
#リストarrayをループで改行して出力する
for word in array:
print(word)
#内包表記で出力する
print('----内包表記----')
[print(word) for word in array]
求められる出力に対して冗長な箇所はコメントアウトします。
複数行のコメントアウトは、「’」を3つの「”’」か、「”」を3つの「”””」を使います。
array='He likes paiza'.split(' ')
'''
print(array)
#リストarrayをループで改行して出力する
for word in array:
print(word)
#内包表記で出力する
print('----内包表記----')
'''
[print(word) for word in array]提出用にスッキリとした最小限のコードに致しました。
array='He likes paiza'.split(' ')
[print(word) for word in array]プログラムを実行した出力結果です。

■ GASでの解き方 ■
今度は、同じ問題をGASで解いてみます。
まず、スプレッドシートにこの様に配置しました。

この黄色く塗りつぶしたセルの所に二次元配列として取得した文字列が格納された配列を出力します。
空白区切りの文字を分割して配列に格納して、更にループを使って二次元配列にします。
※スプレッドシートに表示する場合は、二次元配列としての配列に追加をして作成します※
手順はこのようになります。
1:SpreadSheetAppから階層を辿って現在のシートにアクセスする
2:splitメソッドを使って文字列を分割して配列arrayに代入する
3:分割した文字列が配列arrayに追加出来たことをログ出力で確認する
4:配列arrayに格納された文字列を二次元配列として追加する配列array2を宣言する
5:ループを使ってarrayに格納された文字列を二次元配列としてarray2に追加する
6:スプレッドシートに出力する前に、ログでarray2を出力して確認する
7:array2をスプレッドシートの黄色いセルに出力する
手順1: SpreadSheetAppから階層を辿って現在のシートにアクセスする
const ss = SpreadsheetApp.getActiveSheet();
ここで定数ssにSpreadsheetAppから階層を辿ってアクティブシートにアクセスしています。
このコードを関数「standardInput2」の中に書いていきます。
Standard Inputで、「標準入力」の意味です。
function standardInput2() {
//SpreadSheetAppから階層を辿って現在のシートにアクセスする
const ss=SpreadsheetApp.getActiveSheet();
}手順2:splitメソッドを使って文字列を分割して配列arrayに代入する
const array=’He likes paiza’.split(‘ ‘)
function standardInput2() {
const ss=SpreadsheetApp.getActiveSheet();
//splitメソッドを使って文字列を分割して配列arrayに代入する
const array='He likes paiza'.split(' ');
}手順3:分割した文字列が配列arrayに追加出来たことをログ出力で確認する
console.log(array);
コードと実行結果です。
function standardInput2() {
const ss=SpreadsheetApp.getActiveSheet();
const array='He likes paiza'.split(' ');
//分割した文字列が配列arrayに追加出来たことをログ出力で確認する
console.log(array);
}
手順4:配列arrayに格納された文字列を二次元配列として追加する配列array2を宣言する
let array2=[];
function standardInput2() {
const ss=SpreadsheetApp.getActiveSheet();
const array='He likes paiza'.split(' ');
console.log(array);
//スプレッドシートに出力する二次元配列array2を宣言
let array2=[];
}手順5:ループを使ってarrayに格納された文字列を二次元配列としてarray2に追加する
function standardInput2() {
const ss=SpreadsheetApp.getActiveSheet();
const array='He likes paiza'.split(' ');
console.log(array);
let array2=[];
//ループを使ってarrayに格納された文字列を二次元配列としてarray2に追加する
for(let i=0;i<array.length;i++){
array2.push([array[i]]);
}
}
手順6:スプレッドシートに出力する前に、ログでarray2を出力して確認する
console.log(array2);
function standardInput2() {
const ss=SpreadsheetApp.getActiveSheet();
const array='He likes paiza'.split(' ');
console.log(array);
let array2=[];
for(let i=0;i<array.length;i++){
array2.push([array[i]]);
}
//スプレッドシートに出力する前に、ログでarray2を出力して確認する
console.log(array2);
}
手順7:array2をスプレッドシートの黄色いセルに出力する
ss.getRange(2,1,array2.length).setValues(array2);
function standardInput2() {
const ss=SpreadsheetApp.getActiveSheet();
const array='He likes paiza'.split(' ');
console.log(array);
let array2=[];
for(let i=0;i<array.length;i++){
array2.push([array[i]]);
}
console.log(array2);
//array2をスプレッドシートの黄色いセルに出力する
ss.getRange(2,1,array2.length).setValues(array2);
}実行後のスプレッドシートです。

お疲れ様でした。ブレイクタイムPhotoは、

お台場の観覧車です。
扇風機みたいですね(笑)
ご精読有難うございました。
■ GASの入門書の紹介です ■
詳解! Google Apps Script完全入門 [第3版]
単行本
Kindle版(電子書籍)
■ 関連記事 ■
paizaレベルアップ問題集「標準入力その2」へ戻る
paizaレベルアップ問題集_PythonとGASのコード紹介トップページへ
写真クリエイターとしての活動
自己紹介
