No.3ベストアンサー
- 回答日時:
VBAでVLOOKUPが使えます。
関数でよいのですが、あえてやれば
H1:I4に
101和室A
102和室B
201洋室S
301ホールA
Private Sub Worksheet_Change(ByVal Target As Range)
On Error GoTo ext1
If Target.Column = 1 Then
If Target = "" Then
r = Target.Row
Cells(r, "B") = ""
Else
r = Target.Row
Cells(r, "B") = WorksheetFunction.VLookup(Target, Range("h1:i5"), 2, False)
End If
End If
ext1:
End Sub
結果
A列に入力するとして、B列に表示
A列 B列
201洋室S
301ホールA
201洋室S
311
211
Delete、オフコード値などはテスト済みですが。
ありがとうございます。
そうですか、VBAで関数を使うという手もありましたね。この方法でも試してみたいと思います。
ありがとうございました。
No.2
- 回答日時:
マクロですか・・・
関数のVLOOKUPかHLOOKUPを使う方法が良いのではないでしょうか?
(1)基本になる部屋番号・部屋名のリストを作ります。
このリストは実際に運用している表とは少し離れたところ(例えばF列に部屋番号・G列に部屋名)に作る方がよいです。
(2)部屋名を表示させたい列(B列ですね)を選択し、関数ボタンを押下。検索/行列からVLOOKUPを選択してください。
(3)検索値:検索させるデータ、つまり部屋番号を入力するA列を指定。
範囲:(1)で作っておいたリスト
列番号:(1)のリストの何列目に部屋名があるのか。今回は「2」ですね
検索の型:今回は 「0」 で良いでしょう。
こうすると、A列に部屋番号を入れたら自動的にB列に部屋名を表示するようになります。マクロの必要はないでしょう。
関数を入れてしまうと、消してしまった時に焦る人がいます(笑)
ですから、できるだけワークシート上には関数を書きたくないのです。
保護をかけると、行削除等困ることもでてきますし。
ですから入力したら「あれ?もう入ってる」と感じてもらえるようにしたかったのです。
ありがとうございました。
No.1
- 回答日時:
>部屋番号が入力(変更)されたら、マクロを実行して部屋名を自動的に入力したいのですが、どうしたらいいでしょうか?
これをわざわざマクロで?
数式だったら
=if(b1=100,"和室",if(b1=200,"リビング",""))
マクロで
Sheet module に
Private Sub Worksheet_Change(ByVal Target As Range)
With Target.Cells(1, 1)
If Intersect(.Cells, Range("b:b")) Is Nothing Then Exit Sub
Select Case .Value
Case 100
x = "和室"
Case 200
x = "リビング"
End Select
.Offset(, 1).Value = x
End With
End Sub
この回答への補足
すみません。この方法でやってみたいのですが
アクティブセルがA列にあります。
With Target.Cells(1, 1)
If Intersect(.Cells, Range("b:b")) Is Nothing Then Exit Sub
.Offset(, 1).Value = x
以上の3行を修正する必要があると思うのですが
いかがでしょうか?
Intersectがよく分からず困っています。
大変申し訳ありません。宜しくお願い致します。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【お題】絵本のタイトル
- ・【大喜利】世界最古のコンビニについて知ってる事を教えてください【投稿~10/10(木)】
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・ハマっている「お菓子」を教えて!
- ・最近、いつ泣きましたか?
- ・夏が終わったと感じる瞬間って、どんな時?
- ・10秒目をつむったら…
- ・人生のプチ美学を教えてください!!
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
すべてのシートを選択してエク...
-
エクセルで時刻を自動入力する方法
-
エクセル。ブック内検索で重複...
-
Excelのデータが重いのはなぜで...
-
エクセルで漢字がうまく並び替...
-
Excel2007入力規則
-
「未使用」と「不使用」ってど...
-
ローマ字入力で「トゥ」を入力...
-
1点の辻の字に変換したいがエク...
-
コマンドプロンプトで表示が多...
-
もしセルが"#N/A"なら~をする...
-
Excelでエラー(#N/Aなど)値を...
-
PPTのスライド表示の画面の位置...
-
Eエクセルの計算方法で空欄を0...
-
コマンドプロンプトが実行中か...
-
西暦の2桁表記に使うアポスト...
-
エクセルからアクセスにインポ...
-
「T」「H」「C」などだけが入力...
-
【EXCEL】関数で計算された数字...
-
高速フーリエ変換でデータ数が...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
すべてのシートを選択してエク...
-
Excel VBA 答えが0になってし...
-
エクセルで時刻を自動入力する方法
-
EXCEL VBA 区切り位置のプログ...
-
Excelのデータが重いのはなぜで...
-
合計が0の行を削除
-
エクセルで、「袋詰め問題」を...
-
エクセルマクロについて データ...
-
エクセルで漢字がうまく並び替...
-
エクセルで隣のセルと同じ数字...
-
【Excel】リストの表示・非表示
-
excel関数orマクロ:データ入...
-
Excel2007入力規則
-
エクセルの計算式教えてください
-
Excelでキーワード検索後にその...
-
excel フレームのように一部...
-
エクセルの入力 エンターキーで...
-
エクセルの列に三角印と*印が?
-
EXCELで請求書を作りたいのですが
-
エクセルで人名を50音順に表...
おすすめ情報