ここから本文です

大量のシート、シート名取得、列指定の統計取りたい 教えてください。 都道府...

kum********さん

2017/7/823:50:22

大量のシート、シート名取得、列指定の統計取りたい

教えてください。
都道府県別のシートがあります。
シートは都道府県名です。

シートの中の特定の列に文字が記入されたセルの個数を統計用のシートにまとめたいです。

マクロ等は基本使えませんが、シート名を取得するマクロを見つけそれでシート名は取得できました。

https://detail.chiebukuro.yahoo.co.jp/qa/question_detail/q132956092...)のコードをコピペにしました。

そこから、COUNTAとINDIRECTの数式が使われるかと思うのですが、そこからエラーでて計算がうまくいきません。
先ほどのマクロで取得したシート名がA2にあり、
INDIRECTで調べたい個数が各シートのB列にある場合、
数式はどうしたらいいのでしょうか…教えてください。

この質問は、活躍中のチエリアン・専門家に回答をリクエストしました。

閲覧数:
38
回答数:
1
お礼:
250枚

違反報告

ベストアンサーに選ばれた回答

sk_********さん

2017/7/913:57:01

セル[B2]に入れる数式
=COUNTA(INDIRECT(A2&"!B:B"))

で良いと思いますが、INDIRECT関数は、人によってはパフォーマンス等を気にし、避ける傾向があることは知っておくと良いかもしれません。

https://www.excelspeedup.com/kousokuka/

https://note.chiebukuro.yahoo.co.jp/detail/n450


■INDIRECT関数を使わない方法は次です。

まず、標準モジュール※に下記のコードを貼り付けてください。

Function FCountA(SN, Col As String) As Long
FCountA = Application.CountA(Range(SN & "!" & Col & ":" & Col))
End Function

※Excelが開いている状態で「Alt」+「F11」を押すとVBEが起ち上がる。そこで 挿入 → 標準モジュール

該当シートのセル[B2]に入れる数式
=FCountA(A2,"B")

これは、自身で関数をつくって利用する方法です。
FCountA関数の最初の引数は、シート名、次の引数は列番号です。
実質マクロなので、この方法もよしあしですが。

セル[B2]に入れる数式
=COUNTA(INDIRECT(A2&"!B:B"))...

質問した人からのコメント

2017/7/11 18:24:18

とても分かりやすく教えていただいてありがとうございます!
コードも書いていただいて助かりました!
ありがとうございました!

この質問につけられたタグ

みんなで作る知恵袋 悩みや疑問、なんでも気軽にきいちゃおう!

Q&Aをキーワードで検索:

Yahoo! JAPANは、回答に記載された内容の信ぴょう性、正確性を保証しておりません。
お客様自身の責任と判断で、ご利用ください。
本文はここまでです このページの先頭へ

「追加する」ボタンを押してください。

閉じる

※知恵コレクションに追加された質問は選択されたID/ニックネームのMy知恵袋で確認できます。

不適切な投稿でないことを報告しました。

閉じる