質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

while

Whileは多くの言語で使われるコントロール構造であり、特定の条件が満たされる限り一連の命令を繰り返し実行します。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

2回答

489閲覧

gas while文使い方

gomagoma00

総合スコア2

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

while

Whileは多くの言語で使われるコントロール構造であり、特定の条件が満たされる限り一連の命令を繰り返し実行します。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2020/09/26 09:12

前提・実現したいこと

while文によって空白を追加したい

発生している問題・エラーメッセージ

while文が機能していないのか空白が追加されません。

該当のソースコード

function compare(data) {
const nullarray = [""]
let newarray = []
for(var i=1; i <300 ; i++){
if(data[i][15] !== "ok"){
newarray.push(data[i])
}
else{
continue
}
let matchCount = 0
for(var j=1; j < 301 ; j++){
if(i !== j && data[i][1] === "SinglePhrase" && data[j][1] === "SinglePhrase" && data[i][15] !== "ok" && data[j][15] !== "ok"){
if (data[i][12] === data[j][12] ) {
newarray[newarray.length - 1] = newarray[newarray.length - 1].concat(data[j]);
data[j].push("ok")
matchCount += 1
}
}

}

}

while (newarray[newarray.length - 1] < 105) {
newarray[newarray.length - 1] = newarray[newarray.length - 1].concat(nullarray);
}

return newarray }

試したこと

位置を変えたりした。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Zuishin

2020/09/26 11:56

> while (newarray[newarray.length - 1] < 105) { > newarray[newarray.length - 1] = newarray[newarray.length - 1].concat(nullarray); > } 多分ここで無限ループしますね。 GAS は時間が切れたら強制終了するので、他のところが正常に動いたとしてもここより先には進まないはずです。
gomagoma00

2020/09/26 12:28

何か解決策はございますか? if文の内側のループが終わったときにこの処理をさせたいのですが。
Zuishin

2020/09/26 12:56

問題がここだけとは限らないしこちらにはデータも動作環境もないので全ての問題を解決することはできません。おそらくここだけの話ではないと思っています。
papinianus

2021/01/14 03:57

確認したところ、複数の要素をもつ array は < で比較するとき(つまり Numer にするとき) NaN になるので、while に入れないですね。なので while 内が実行されない。されたところで最終行しか補正されないので、修正案の回答を書きました。
guest

回答2

0

javascript

1function compare(data) { 2 //const nullarray = [""] 3 let newarray = [] 4 let maxmatchCount = 0; 5 for(var i=1; i <20 ; i++){ 6 if(data[i][15] !== "ok"){ 7 newarray.push(data[i]) 8 } 9 else{ 10 continue 11 } 12 let matchCount = 0 13 for(var j=1; j < 20 ; j++){ 14 if(i !== j && data[i][1] === "SinglePhrase" && data[j][1] === "SinglePhrase" && data[i][15] !== "ok" && data[j][15] !== "ok"){ 15 if (data[i][12] === data[j][12] ) { 16 newarray[newarray.length - 1] = newarray[newarray.length - 1].concat(data[j]); 17 data[j].push("ok") 18 matchCount += 1 19 } 20 } 21 22 } 23 maxmatchCount = Math.max(maxmatchCount,matchCount); 24 } 25 26 for(let i = 0; i < newarray.length; i++) { 27 while (newarray[i].length < 15 * (maxmatchCount +1)) { 28 newarray[i].push(""); 29 } 30 } 31 return newarray 32} 33function t() { 34 const book = SpreadsheetApp.getActive(); 35 const data = book.getActiveSheet().getDataRange().getValues(); 36 const result = compare(data); 37 const format = result; 38 book.getSheetByName("1").getRange(1, 1, format.length, format[0].length).setValues(format); 39}
ABCDEFGHIJKLMNO
SinglePhrase2345678901134
SinglePhrase23456789012034
SinglePhrase23456789013034
SinglePhrase23456789012034
SinglePhrase23456789013034
SinglePhrase23456789012034
a23456789014034
SinglePhrase23456789014034
a2345678901934
SinglePhrase23456789011034
SinglePhrase2345678901134
SinglePhrase23456789012034
SinglePhrase23456789013034
SinglePhrase23456789012034
SinglePhrase23456789013034
SinglePhrase23456789012034
a23456789014034
SinglePhrase23456789014034
SinglePhrase2345678901934
SinglePhrase23456789011034

投稿2021/01/14 03:52

papinianus

総合スコア12705

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

コメントにもありますし、別の質問でもかいたようにデータサンプルがなければ確認のしようがないです。

あらためて書きますが

  • サンプルデータを開示してください。
  • compare の呼び出し元の関数を開示してください。
  • 別質問のほうの t() を実行してください。
  • やりたいことを具体化してください。
    率直に申し上げますが compare でつくっているデータ形式は異常です。フレーズという名前からして、単語をまとめあげているのではないかと思うのですが、出現頻度によって、横方向の長さが違うというのは変ですし、本来縦方向に意味が揃っている値(singlePhraseがあるB列)をよこにずらすとセル関数などであつかいづらいかたちになって、収拾がつかないです。
    105 までふやそうとしていますが、出現頻度によっては 105 でおさまる(7回)とはいえないですよね。早晩破綻します。逆にデータが最大で 60 しかないのに 105 つくるのは無意味です。
    その while でやっているのが別質問の squarize です。
    とてもおすすめできないですが、仮に重複キーワードをまとめあげしたいのであっても、セルを横にのばすのではなく、各セルごとに改行で連結していくとか、数値であれば足すとかいった方法で四角形の構造をくずさずにまとめる必要があると考えます。

投稿2021/01/14 03:21

papinianus

総合スコア12705

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問