
例えば、A1に「ABC」、A2に「DEF」と書いてあって、A3にこれらを結合して「ABCDEF」という文字列を作る場合は以下のマクロでできます。しかし、A1, A2の文字の色はコピーされません。A1が赤色であってもA3には全て黒色でコピーされてしまいます。
Sub con()
Range("A3").Value = Range("A1").Text + Range("A2").Text
End Sub
これを文字の色やボールド、斜体、アンダーラインなども含めてコピーする方法を教えてください。よろしくお願いします。
No.5ベストアンサー
- 回答日時:
こんにちは。
これは、コピーされる側個々のセルは、全体単位で、ペーストされる側は、個別の書式でプロパティが写されます。
Sub CopyFont1()
Dim a As Range, b As Range
Dim c As Variant, k As Integer
Set a = Range("A1")
Set b = Range("A2")
With Range("A3")
.Value = a.Value & b.Value
For Each c In Array(a, b)
With .Characters(k + 1, Len(c.Value) + k + 1).Font
.Bold = c.Font.Bold
.Color = c.Font.Color
.Italic = c.Font.Italic
.Name = c.Font.Name
.Size = c.Font.Size
.Underline = c.Font.Underline
End With
k = k + Len(c.Value)
Next
End With
End Sub
回答ありがとうございます。求めていた結果が得られると同時に、マクロの書き方としてもたいへん参考になりました。セルに書き込んだ文章の重要部分を赤にしたりボールドにしているのですが、それらを集めてまとめる処理を行うために、この質問をさせていただきました。
No.4
- 回答日時:
(1)+や&は文字列の「値」としての面だけを注目するものです。
Textプロパティも同じです。わかっておられると思いますが、原理的なことなので、まずしっかり認識すべきです。
(2)書式を含めて、移してくれるのは、Copyですが、A1セルとA2セルのどちらを優先するのかが決まっていません、決められません。
ですから質問には答えようがない。
(3)さらに、色は黒以外を優先、斜体はイタリック優先、アンダーラインはありを優先という条件を考えているとしたら、Copyにはその条件はつけられません。A1優先なら、A1の書式をA3にコピーすればよいように思います。これはマクロの記録でも見てまねて、1、2行ですむでしょう。
(4)人間には常識的な(3)で触れた、優先の条件を、VBAの中に書きこめばできることですが、シコシコの世界で、面倒くさくて、今までそういう必要性を経験したことがないせいもあって、書く気がしない(略)。
黒色以外の優先関係、フォントの優先関係など細かい点はどうするのという問題もあります。

No.3
- 回答日時:
試しに実行したところ以下のようなコードが得られましたが参考になりませんか?
A1の書式がA3にコピーされます。
Range("A1").Select
Selection.Copy
Range("A3").Select
Selection.PasteSpecial Paste:=xlPasteFormats, Operation:=xlNone, _
SkipBlanks:=False, Transpose:=False
No.2
- 回答日時:
>ちょっと考えるとコピーする文字の属性を一文字づつ新しい文字列に設定するVBAを書く必要があるかに思えます。
これよりもっと簡単な方法はないのでしょうか?私も、まとめてうまくやる方法が無いように思います。
fontStyleで標準・ボールド・斜体がまとめてできるのが救い。
---------------------------------------------------
Public Sub cat()
Dim s1 As Range, s2 As Range
Dim d As Range
Dim i, j
Set s1 = Range("A1")
Set s2 = Range("A2")
Set d = Range("A3")
d.Value = s1.Text & s2.Text
For i = 1 To Len(s1.Text)
d.Characters(i, 1).Font.Color = s1.Characters(i, 1).Font.Color
d.Characters(i, 1).Font.FontStyle = s1.Characters(i, 1).Font.FontStyle
d.Characters(i, 1).Font.Underline = s1.Characters(i, 1).Font.Underline
Next
i = Len(s1.Text)
For j = 1 To Len(s2.Text)
d.Characters(i + j, 1).Font.Color = s2.Characters(j, 1).Font.Color
d.Characters(i + j, 1).Font.FontStyle = s2.Characters(j, 1).Font.FontStyle
d.Characters(i + j, 1).Font.Underline = s2.Characters(j, 1).Font.Underline
Next j
End Sub
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
エクセルの書式を保持したまま結合するVBA
Excel(エクセル)
-
Excelでセル参照したとき、書式も一緒に持ってくるには?
Windows Vista・XP
-
CONCATENATEで結合した文字列の一部の文字色を変更するには
Excel(エクセル)
-
-
4
EXCEL VBA 文中の書式ごと複写するには
Visual Basic(VBA)
-
5
VBA 書式設定を保持したままセル内の文字を追記
Excel(エクセル)
-
6
数式による空白を無視して最終行を取得するマクロ
Excel(エクセル)
-
7
Excel VBA セル内に設定されたテキストを書式ごとコピー(複数セル)
Excel(エクセル)
-
8
エクセルで文字列の結合したときのフォントの大きさを指定する。
Excel(エクセル)
-
9
VBAで文字を反映させると255文字の制限になってしまいます。
Visual Basic(VBA)
-
10
全ての変数を一気にリセットする方法はありますか?
PowerPoint(パワーポイント)
-
11
VBAでセルの書式を変えずに文字列を置換する方法をご教示ください
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
セックスする度に胸が大きくな...
-
週1ペースで会うカップルでデー...
-
セックスしてる時に気持ちいい...
-
オナ禁中はセックスしてもいい...
-
僕の心が狭いのでしょうか…?セ...
-
母子相姦経験者ですが、日本で...
-
初めて泊まりにきてくれる彼女...
-
恋人とセフレの違いはなんです...
-
セックスについて。 彼が正常位...
-
セックスする時なぜ声出るの
-
胸が揺れるくらい激しいセック...
-
おじさんになってから若い女性に
-
30代前半男性の性欲
-
彼女が噛んできます。 歯型がつ...
-
アナルファックと普通のセック...
-
謎
-
50歳代女性の結婚
-
貞操観念の低い女性について
-
彼女とのセックスに新鮮味を感...
-
高校生の性行為
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
セックスする度に胸が大きくな...
-
週1ペースで会うカップルでデー...
-
セックスしてる時に気持ちいい...
-
恋人とセフレの違いはなんです...
-
アナルファックと普通のセック...
-
僕の心が狭いのでしょうか…?セ...
-
おじさんになってから若い女性に
-
胸が揺れるくらい激しいセック...
-
オナ禁中はセックスしてもいい...
-
セックスする時なぜ声出るの
-
セックスについて。 彼が正常位...
-
未成年同士でラブホに行った際...
-
母子相姦経験者ですが、日本で...
-
付き合って1ヶ月でヤった後別れ...
-
初めて泊まりにきてくれる彼女...
-
彼女が噛んできます。 歯型がつ...
-
30代前半男性の性欲
-
彼女とのセックスに新鮮味を感...
-
セックス前
-
セックスする時って会話します...
おすすめ情報