質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Q&A

4回答

5677閲覧

VBA セルの条件付き書式の設定をコピーすることは可能でしょうか。

King_of_Flies

総合スコア382

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

0グッド

0クリップ

投稿2018/01/30 09:02

編集2018/01/31 00:15

以前、範囲選択したセルのデータのコピー方法を教えていただき、
下記実装で動作確認が取れましたが、
セルの条件付き書式の設定に関してコピーをしたいのですが、
参考となるサイトがあまりありませんでした。

VBA

1Dim testRange() As Variant 2testRange = Range("A1:A3").Value 3Range("B1:B3").Value = testRange 4Range("A1:A3").clearContents 5Range("A1:A3").clearFormats

上記の処理は簡単に作成した処理です。
現状、Range("A1:A3")のValueは("B1:B3")に格納できますが、
Range("A1:A3")の持つ条件付き書式の設定が格納できていません。

clearContentsでValueが一括削除でき、
clearFormatsで条件付き書式の設定が一括削除できているのですが、

Valueの格納は
Range("A1:A3").Valueで良くて、
Formatsの格納が
Range("A1:A3").Formatで出来ないのでそのようなプロパティにあたるものがないか調べてみました。

そこでFormatConditionsというものを見つけたのですが、

VBA

1Dim testRange_value() As Variant 2testRange_value = Range("A1:A3").Value 3 4Dim testRange_format() As FormatCondition 5testRange_format = Range("A1:A3").FormatConditions 6 7Range("B1:B3").Value = testRange 8Range("B1:B3").FormatConditions = testRange_format 9 10Range("A1:A3").clearContents 11Range("A1:A3").clearFormats

としても、条件付き書式の設定ができません。

なにか良い方法ございますでしょうか。

追記
クリップボードを使用するコピーは控えたいと考えています。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答4

0

Dim testRange_format As FormatCondition
Dim testRange_value() As Variant

testRange_value = Range("A1:A3").Value
testRange_format = Range("A1:A3").FormatConditions(1)

Range("B1:B3").Value = testRange

Range("B1:B3").FormatConditions.Delete
Range("B1:B3").FormatConditions.Add _
testRange_format.Type,testRange_format.Operator, testRange_format.Formula1

With Range("B1:B3").FormatConditions(1).Interior
.Color = testRange_format.Interior.Color
End With

Range("A1:A3").clearContents
Range("A1:A3").clearFormats

上記のように各プロパティごとに設定をしていくというのはどうでしょう?

投稿2018/01/31 00:47

Mustang32861341

総合スコア100

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

.copyで条件付き書式はコピーされませんでしたか?

投稿2018/01/30 09:24

sazi

総合スコア25173

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

King_of_Flies

2018/01/30 23:58

.Copyではクリップボードが使用されるようで、 変数か何かにコピーしたデータを一時格納したいのですが、 その方法が不明という段階です。
guest

0

VBA 条件付き書式 コピー で検索

投稿2018/01/30 09:23

ExcelVBAer

総合スコア1175

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

VBA セルに条件付き書式を設定する
.FormatConditions.Add(~)って書き方のようです。

投稿2018/01/30 09:09

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問