おはようございます。
EXCELで、シート名をセルに表示させたいのですが、
該当のセルをダブルクリックしないと、シート名が反映されません。セルには直前のシート名が表示されます。
=AI6・・・シート名を表示させるセルで、この例では
3-41が表示される。
以下は、シート名の取得の関数です。
=CELL("filename")
=LEFT(AI3,FIND("[",AI3)-1)
=MID(AI3,FIND("[",AI3)+1,FIND("]",AI3)-FIND("[",AI3)-1)
=RIGHT(AI3,LEN(AI3)-FIND("]",AI3))
\\Server_pc\data\総務部\17年度\[17年度P.3.xls]3-41
\\Server_pc\data\総務部\17年度\17年度P.3.xls
3-41
No.2
- 回答日時:
>該当のセルをダブルクリックしないと、シート名が反映されません。
>セルには直前のシート名が表示されます。
ツール → オプション → 計算方法
で「手動」にチェックが入っているとか・・・
もしその場合「自動」にチェックを入れればリアルタイムに計算するようになります
そうでなかったらごめんなさい
No.3
- 回答日時:
空いたセルに、何か簡単な関数を入れてみて、計算結果がすぐでないようなら、#2でおっしゃている、自動計算になっていないケースでないですか。
シート名表示の関数は長く、難しいですが、それが関連しているかどうか、切り分けるのが、原因究明のコツです。(人間は何か悪いことが起こると、最近やった、極くたまにしかしない事象が原因と思いやすいですね。)
No.4
- 回答日時:
こんにちは。
計算方法が自動に入っていても、「\\Server_pc\data\」では、即座に反応しませんね。
シートはブックの中で取れるように、ユーザー定義関数を作ったらいかがでしょうか?
ただ、仮にそうしても、現在のCELL関数と同様に、関数の性質が、「揮発性」ですから、開いてから、そのロケーションの情報を取って表示しています。ですから、終了時に、何もしなくても、変更があったということで、保存を求められることになります。ただ、ダブルクリックなどしなくても良くなるだけ、ということです。
'-------------------------------------
作成方法:
Alt + F11 (Altを押しながらF11)を押すと、Visual Basic Editor 画面が出てきます。
次に、メニューの[挿入]-[標準モジュール]と開けて、クリックすると、画面が現れますので、以下のコードを貼り付けて、Alt + Q で、画面を閉じてください。
Function SheetName(Optional セル As Range)
Dim r As Range
If セル Is Nothing Then
If TypeName(Application.Caller) = "Range" Then
Set r = Application.Caller
Else
Exit Function
End If
Else
Set r = セル
End If
SheetName = r.Parent.Name
End Function
'--------------------------------------
注意: なお、これは、Public ステートメントをつけても、グローバル化(Globalization)はしません。みなさん、Public キーワードと、混同される方がおおいので、一応、載せておきます。
使い方:
シート上で、
=sheetname()
と入力すれば、アクティブシート
=sheetname(Sheet3!A1)
と入力すれば、Sheet3 と表示されるはずです。
おはようございます。
理由(原因)は理解できるようになりました。
マクロの考え方もすごく役立ちました。
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) エクセルの数式で教えてください。 1 2023/07/31 15:49
- Excel(エクセル) エクセルの数式で教えてください。 1 2023/02/02 10:20
- その他(Microsoft Office) エクセルの数式で教えてください。 2 2023/01/12 13:51
- Excel(エクセル) エクセルのマクロについて教えてください。 1 2023/01/26 09:50
- Visual Basic(VBA) 2つのシートの任意のセルの番号が一致したら、一致した行をコピーする VBA 2 2023/06/19 20:48
- Excel(エクセル) エクセルの数式で教えてください。 3 2023/06/06 10:13
- その他(プログラミング・Web制作) Pythonを勉強しています。 5 2023/08/25 09:51
- Excel(エクセル) ExcelVBAの、Index matchについて 2 2023/04/18 16:57
- その他(Microsoft Office) エクセルの休日について教えてください。 1 2023/01/06 15:45
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 3 2022/06/10 09:24
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセル初心者です 関数の入れ...
-
【関数】先頭だけにある、半角...
-
エクセル 白黒印刷で白線を印刷...
-
Excelのチェックボックスの使い...
-
【関数】適切な文字数の数字を...
-
Excelのpivotについて質問です
-
Excel ピボットテーブルで日付...
-
LOOKUP関数を使えばいいのでし...
-
エクセル関数を教えてください
-
エクセルのセルに同じ大きさの...
-
UNIQUE関数が使えないバージョ...
-
excelの不要な行の削除ができな...
-
エクセルで「-0.0」と表示さ...
-
時間によってファイル名が変わ...
-
WPS OFFICEでの縦書きについて
-
エクセルの関数について教えて...
-
Aというブックの1というシート...
-
【マクロ】シート名を取得する...
-
VBA Private Sub Worksheet_Cha...
-
VBA、Excelのworkbook.open に...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excel 2019 のピボットテーブル...
-
[関数得意な方]教えて下さい・...
-
Excelにてある膨大なデータを管...
-
[関数について]わかる方教えて...
-
Excel初心者です。 詳しい方、...
-
excelの不要な行の削除ができな...
-
エクセル関数に詳しい方教えて...
-
INDIRECTを使わず excelで複数...
-
[オートフィルタ]で抽出された...
-
エクセルの神よ、ご回答を! エ...
-
エクセル関数に詳しい方、教え...
-
各ページの1番上の表示について
-
Excelで写真のような表を作った...
-
エクセルで不等号記号(≠)が上に...
-
数学 Tan(θ)-1/Cos(θ)について...
-
Excel 2019 は、SPILL機能があ...
-
Excelで全角を半角にしたいので...
-
条件付き書式を教えてください
-
Excel フィルターを掛けた状態...
-
[オートフィルタ]の適用範囲の...
おすすめ情報