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

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

新規登録して質問してみよう
ただいま回答率
85.31%
Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Q&A

解決済

3回答

791閲覧

自動採番を行う配列数式を、組み込み関数のみで作成したい

Nao.K

総合スコア41

Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

0グッド

0クリップ

投稿2023/06/22 03:58

編集2023/06/22 04:32

実現したいこと

自動採番を行う配列数式を、組み込み関数のみで作成したい

前提

下記のように、対象の列が空白でない場合だけ番号をつけるような数式を作りたいのです。
ただし、列を挿入したときにも自動で番号をつけるようにしたく、配列数式で実装したいです。

ABC
(空白)
1=AUTONUMBERING(C:C)テキスト
2テキスト
(空白)
3テキスト
(空白)
(空白)
4テキスト

試したこと

配列関数でなければ、問題なくできます。
(COUNTAを使用した方法)

ABC
(空白)
1=IF(ISBLANK(C2), "", COUNTA(C$2:C2))テキスト
2=IF(ISBLANK(C3), "", COUNTA(C$2:C3))テキスト
=IF(ISBLANK(C4), "", COUNTA(C$2:C4))(空白)
3=IF(ISBLANK(C5), "", COUNTA(C$2:C5))テキスト
=IF(ISBLANK(C6), "", COUNTA(C$2:C6))(空白)
=IF(ISBLANK(C7), "", COUNTA(C$2:C7))(空白)
4=IF(ISBLANK(C8), "", COUNTA(C$2:C8))テキスト

ただし、前述のように途中に列を挿入すると、オートフィルなりコピペなりしないと数式がない行ができてしまいます。

また、GASも利用してみました。下記の関数を入力することで、一応は目的の動作ができました。

JavaScript

1/** 2 * 自動採番(空白はスキップ) 3 * @param {Array<Array<any>>} colRange - 採番対象の列 4 * @return {Array<number | string>} - 番号の配列(2次元) 5 */ 6function AUTONUMBERING(colRange) { 7 const sheet = SpreadsheetApp.getActive().getActiveSheet(); 8 const firstRow = sheet.getActiveCell().getRow() - 1; 9 const lastRow = sheet.getLastRow() - 1; 10 const numArr = []; 11 let count = 0; 12 for (let i = firstRow; i <= lastRow; i++) { 13 numArr.push([colRange[i][0] ? ++count : ""]); 14 } 15 return numArr; 16};

ただ、こちらは実行開始に2〜3秒ほどかかり、まれにLoading...表示のまま止まることがあるので、GASは使用しないで行ければと思ってます。

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

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

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

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

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

guest

回答3

0

ベストアンサー

これだとどうですか

=ARRAYFORMULA(IF(C2:C="","",COUNTIFS(C2:C,"<>'",ROW(C2:C),"<="&ROW(C2:C))))

投稿2023/06/22 04:37

bebebe_

総合スコア520

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

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

Nao.K

2023/06/22 10:10 編集

無事取得できました! countIfsの条件部分を配列にする方法は思いもよらず。。。 有難う御座います!
guest

0

bebebe_さんの回答を参考に、

  • 行番号を指定しなくても入力行からカウントできるように
  • 最終行以降に、不要な空文字列が挿入されないように

改造し、下記のように名前付き関数として定義してみました。
bebebe_さん、有難う御座いました!


関数:AUTONUMBERING(対象列)

sas

1= let( 2 range, 対象列, 3 firstRow, row(), 4 lastRow, max(arrayFormula( 5 row(range) * n(range <> "") 6 )), 7 shortenedRange, offset( 8 index(range, firstRow, 1), 9 0, 0, 10 lastRow - firstRow + 1, 1 11 ), 12 arrayFormula( 13 if(shortenedRange = "", 14 "", 15 countIfs( 16 shortenedRange, "<>'", 17 row(shortenedRange), "<=" & row(shortenedRange) 18 ) 19 ) 20 ) 21)

投稿2023/06/22 06:50

編集2023/06/22 06:53
Nao.K

総合スコア41

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

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

0

この回答はGPT-4による自動生成回答です

配列数式を使用して、自動採番を行う方法を以下に示します。

方法

=ArrayFormula(IF(LEN(C2:C), IF(C2:C<>"", ROW(C2:C)-ROW(C2)+1, ""), ""))

説明

  1. LEN(C2:C) で、C列の各セルの文字数を取得します。
  2. IF(C2:C<>"", ROW(C2:C)-ROW(C2)+1, "") で、C列の各セルが空白でない場合、そのセルの行番号から開始行番号を引いて1を足します。これにより、空白でないセルに対して連番が付与されます。
  3. ArrayFormula を使用して、上記の数式を配列に適用します。

この数式をB2セルに入力すると、C列の空白でないセルに対して自動採番が行われます。また、列を挿入しても自動で番号が付与されます。

投稿2023/06/22 03:59

teratail-ai

Powered by GPT-4

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

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

Nao.K

2023/06/22 04:07

空白セルの場合、そもそもカウントを行わないようにしたいです。 NG:1→2→BLANK→4 OK:1→2→BLANK→3
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.31%

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

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

質問する

関連した質問