<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>メッセージ &#8211; とりっぷぼうる</title>
	<atom:link href="https://tripbowl.net/tag/%E3%83%A1%E3%83%83%E3%82%BB%E3%83%BC%E3%82%B8/feed/" rel="self" type="application/rss+xml" />
	<link>https://tripbowl.net</link>
	<description>観光地にはお得なフリーパスあり</description>
	<lastBuildDate>Tue, 01 Aug 2023 11:26:05 +0000</lastBuildDate>
	<language>ja</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=6.6.1</generator>

<image>
	<url>https://tripbowl.net/wp-content/uploads/2021/09/cropped-9363d75a338bc1796f4d8b21a4a8670f-32x32.jpg</url>
	<title>メッセージ &#8211; とりっぷぼうる</title>
	<link>https://tripbowl.net</link>
	<width>32</width>
	<height>32</height>
</image> 
<atom:link rel="hub" href="https://pubsubhubbub.appspot.com"/><atom:link rel="hub" href="https://pubsubhubbub.superfeedr.com"/><atom:link rel="hub" href="https://websubhub.com/hub"/>	<item>
		<title>複数のラベル名を一括で複数のセルの値に書き換える方法</title>
		<link>https://tripbowl.net/vba-label-change/</link>
		
		<dc:creator><![CDATA[とりっぷぼうる]]></dc:creator>
		<pubDate>Tue, 10 Jul 2018 03:50:43 +0000</pubDate>
				<category><![CDATA[ラベル]]></category>
		<category><![CDATA[プログラミング]]></category>
		<category><![CDATA[メッセージ]]></category>
		<category><![CDATA[ユーザーフォーム]]></category>
		<guid isPermaLink="false">https://tripbowl.net/?p=103</guid>

					<description><![CDATA[<p><img src="https://tripbowl.net/wp-content/uploads/2018/07/7bba4fefbea781d6a2d1856e8335dd68.jpg" class="webfeedsFeaturedVisual" /></p>ラベルキャプションをセルの値から一括取得 ボウリングの大会や予約でASで名前登録作業を行っていて、一人目の名前を入れると、空欄の部分に登録した名前が表示され、二人目を登録すると2番目に名前が表示されるのが当然ですが、エク [&#8230;]]]></description>
										<content:encoded><![CDATA[<p><img src="https://tripbowl.net/wp-content/uploads/2018/07/7bba4fefbea781d6a2d1856e8335dd68.jpg" class="webfeedsFeaturedVisual" /></p><h2>ラベルキャプションをセルの値から一括取得</h2>
<p>ボウリングの大会や予約でASで名前登録作業を行っていて、一人目の名前を入れると、空欄の部分に登録した名前が表示され、二人目を登録すると2番目に名前が表示されるのが当然ですが、エクセルでも似たようなことができます。</p>
<p>リーグ成績表でも使用している「選手登録フォーム」で<span class="marker-blue">【新規登録】</span>ボタンを押すと入力した参加者名が表示されるという事です。</p>
<p>この<span class="marker-blue">【新規登録】</span>ボタンに「コマンドボタン」と言いますが、次のような指示を書いています。</p>
<div class="success-box">ユーザーフォームに配置した「会員番号」「選手名前」「AVE」を入力する枠（テキストボックス（TextBox））と「性別」を選択する（オプションボタン（OptionButton））に入力・選択された内容を指定したセルに転記して、さらに、名前「ラベル（Label）」といいますが、【新規登録】ボタンに自動的にあらかじめ指定したセルの値を取得して表示する</div>
<p>と、いう指示を書いています。</p>
<p>選手が誰も登録されていない状態はラベル（Label）はラベル番号で表示されています。</p>
<p><img decoding="async" class="aligncenter size-full wp-image-35" src="https://tripbowl.net/wp-content/uploads/2018/07/2e81fea7b000427decbb4d99267292ab.jpg" alt="LTB選手登録" width="700" height="643" srcset="https://tripbowl.net/wp-content/uploads/2018/07/2e81fea7b000427decbb4d99267292ab.jpg 700w, https://tripbowl.net/wp-content/uploads/2018/07/2e81fea7b000427decbb4d99267292ab-300x276.jpg 300w" sizes="(max-width: 700px) 100vw, 700px" /></p>
<p>「会員番号」「選手名前」「AVE」と入力して「性別」を選択して、<span class="marker-blue">【新規登録】</span>ボタンを押すと</p>
<p><img decoding="async" class="aligncenter size-full wp-image-102" src="https://tripbowl.net/wp-content/uploads/2018/07/fbceaeb70422a354842b273553b45530.jpg" alt="ラベル一括変換後" width="694" height="639" srcset="https://tripbowl.net/wp-content/uploads/2018/07/fbceaeb70422a354842b273553b45530.jpg 694w, https://tripbowl.net/wp-content/uploads/2018/07/fbceaeb70422a354842b273553b45530-300x276.jpg 300w" sizes="(max-width: 694px) 100vw, 694px" /></p>
<p>登録済みの選手名に表示（ラベルキャプション）が一括で切り替わってくれます。</p>
<p>入力した名前が間違っていないかどうかが、入力後すぐに表示されているのでわざわざ、ワークシートのセルを探す必要が無くなるので時間の節約になりますね。</p>
<div class="comment-box">では、実際にはこのようなコードを記述しています</div>
<div class="blank-box bb-tab bb-point bb-blue success-box">Private Sub CommandButton1_Click()<br />
If UserForm1.TextBox1.Value = &#8220;&#8221; Or UserForm1.TextBox2.Value = &#8220;&#8221; Or UserForm1.TextBox3.Value = &#8220;&#8221; Then<br />
MsgBox &#8220;会員番号・選手名前・AVEを入力してください&#8221;<br />
Else<br />
Range(&#8220;AB1&#8221;).Value = UserForm1.TextBox1.Value<br />
Range(&#8220;AC1&#8221;).Value = UserForm1.TextBox2.Value<br />
Range(&#8220;AE1&#8221;).Value = UserForm1.TextBox3.Value<br />
If OptionButton1.Value = True Then<br />
Range(&#8220;AD1&#8221;).Value = &#8220;1&#8221;<br />
ElseIf OptionButton2.Value = True Then<br />
Range(&#8220;AD1&#8221;).Value = &#8220;2&#8221;<br />
End If<br />
Range(&#8220;AB1&#8221;).End(xlDown).Offset(1).Value = Range(&#8220;AB1&#8221;).Value<br />
Range(&#8220;AC1&#8221;).End(xlDown).Offset(1).Value = Range(&#8220;AC1&#8221;).Value<br />
Range(&#8220;AD1&#8221;).End(xlDown).Offset(1).Value = Range(&#8220;AD1&#8221;).Value<br />
Range(&#8220;AE1&#8221;).End(xlDown).Offset(1).Value = Range(&#8220;AE1&#8221;).Value<br />
End If<br />
For i = 44 To 83<br />
With UserForm1.Controls(&#8220;Label&#8221; &amp; i)<br />
.Caption = Cells(i &#8211; 41, 29)<br />
End With<br />
Next i<br />
For j = 84 To 123<br />
With UserForm1.Controls(&#8220;Label&#8221; &amp; j)<br />
.Caption = Cells(j &#8211; 81, 31)<br />
End With<br />
Next j<br />
UserForm1.TextBox1.Value = &#8220;&#8221;<br />
UserForm1.TextBox2.Value = &#8220;&#8221;<br />
UserForm1.TextBox3.Value = &#8220;&#8221;<br />
End Sub</div>
<div class="blank-box bb-yellow">
<ol>
<li>「コマンドボタン１をクリックしたら実行する」というマクロの記述を開始</li>
<li>もしユーザーフォーム１のテキストボックス１が空欄または、ユーザーフォーム１のテキストボックス２が空欄または、ユーザーフォーム１のテキストボックス３が空欄だったら</li>
<li>「会員番号・選手名前・AVEを入力してください」とメッセージを表示する</li>
<li>そうでなかったら（全て入力されていたら）以下のコードを実行する</li>
<li>セル「AB1」にユーザーフォーム１のテキストボックス１の入力値を転記する</li>
<li>セル「AC1」にユーザーフォーム１のテキストボックス２の入力値を転記する</li>
<li>セル「AE1」にユーザーフォーム１のテキストボックス３の入力値を転記する</li>
<li>もしオプションボタン１（男）が選択されていたら</li>
<li>セル「AD1」に半角数字の「1」を転記する</li>
<li>そうではなくもしオプションボタン２（女）が選択されていたら</li>
<li>セル「AD1」に半角数字の「2」を転記する</li>
<li>オプションボタンに関するIfステートメント終了</li>
<li>セル「AB1」の入力済み最終行を見つけてその下の行にセル「AB1」の値を記述する</li>
<li>セル「AC1」の入力済み最終行を見つけてその下の行にセル「AC1」の値を記述する</li>
<li>セル「AD1」の入力済み最終行を見つけてその下の行にセル「AD1」の値を記述する</li>
<li>セル「AE1」の入力済み最終行を見つけてその下の行にセル「AE1」の値を記述する</li>
<li>テキストボックスが空欄でなかった場合のIfステートメント終了</li>
<li>繰り返し処理の変数「i」を宣言し、変数「i」は44～83とする（書き換えたいラベル番号）</li>
<li>Withステートメント開始し、ユーザーフォーム１に配置された「ラベル番号「i」」の名前をセル（i-41行目の29列目）より順に取得して書き換える</li>
<li>名前の書き換えるWithステートメント終了</li>
<li>変数「i」を指定した範囲で繰り返す</li>
<li>繰り返し処理の変数「j」を宣言し、変数「j」は84～123とする（書き換えたいラベル番号）</li>
<li>Withステートメント開始し、ユーザーフォーム１に配置された「ラベル番号「j」」の名前をセル（j-81行目の31列目）より順に取得して書き換える</li>
<li>AVEの書き換えるWithステートメント終了</li>
<li>変数「j」を指定した範囲で繰り返す</li>
<li>ユーザーフォーム１のテキストボックス１を空欄にする</li>
<li>ユーザーフォーム１のテキストボックス２を空欄にする</li>
<li>ユーザーフォーム１のテキストボックス３を空欄にする</li>
<li>マクロの記述終了</li>
</ol>
</div>
<p>変数ってのが、ややこしいいかな？</p>
<p>変数「i」は44～83になっているのは、参加選手名の1番～40番に相当するラベル番号が実は最初の図のように44～83なのです。</p>
<p>その為にラベルの名前を書き換えるのは当然44～83なので、ラベルの番号が変わるから「変数」なんです。</p>
<p>そして取得したいセルは見えないのですが、セルAB1には転記した名前が、セルAB2には「選手名」と記載しています。その為最初に入力された選手名は必ず、セル「AB3」に入力されるようになっています。</p>
<p>なぜならば、入力済み最終行を見つけてその下のセルに入力されるようになっているからです。</p>
<p>ということで、1番目の選手名はセル「AB3」なので3行目。</p>
<p>ということで、</p>
<p>選手番号１はラベル44でセルは3行目になり、44引く3は、-41となります。</p>
<p>また、AB列はAから数えると29番目の列なので列番号は29です。</p>
<p>これがCells(i-41,29）という意味です。</p>
<p>[temp id=19]</p>
]]></content:encoded>
					
		
		
			</item>
	</channel>
</rss>
