セルをコピーしてメモ帳などのテキストエディタに貼り付けると、””(ダブルクォーテーション)で囲まれますよね。
現在は、テキストエディタでデーターを使用するときに、複数セルを選択コピーして、ワードに張り付けて再度コピーして利用していますが。
複数のアクティブセルをコピーして、ワードに貼付け、それをコピーする操作をマクロにできないでしょうか。テキストエディタで使用するため。
*ダブルクォーテーションなしでテキストエディタに使用できるならその他の方法でもよいのですが・・・
何度も同じ作業をするために、ワードはすべて選択で貼付け、コピーしています。
複数のアクティブセルは、行・列は変化し、選択セル数は変化します。
データーはエクセルのシートのテーブルでソートしたあるデーターを利用するため。
又、あるサイトで「エクセルのコピー時にダイレクトにクリップボード操作するマクロ」を見つけましたが、アクティブセルのみコピーで、複数セルに対応してないとのこと
コード
Sub Copy()
Dim buf As String, buf2 As String, CB As New DataObject
buf = ActiveCell
With CB
.SetText buf ''変数のデータをDataObjectに格納する
.PutInClipboard ''DataObjectのデータをクリップボードに格納する
.GetFromClipboard ''クリップボードからDataObjectにデータを取得する
buf2 = .GetText ''DataObjectのデータを変数に取得する
End With
End Sub
これを複数のセル(アクティブにした複数セル)に対応できないものでしょうか?
No.6ベストアンサー
- 回答日時:
前回よりも、遅い反応になってしまうかもしれません。
DataObject の反応がイマイチなので、エラートラップをつけました。
以下は、調子が悪いようでしたら、全面的に、Win APIに切り替えなくてはならなくなると思います。
'//
Sub myClipBoard()
Dim buf As Variant, buf2 As String
Dim Rng As Range
Dim x As Variant
Dim t As String
Dim i As Long, j As Long
Dim CB As Object
Const DELIM As String = " " 'デリミタ
Const CLSID As String = "1C3B4210-F441-11CE-B9EA-00AA006B1A69"
On Error GoTo ErrHandler
Set CB = Nothing
Set CB = GetObject("new:" & CLSID)
If TypeName(Selection) = "Range" Then
Set Rng = Selection
If Rng.Cells.Count > 1 Then
For i = 1 To Rng.Rows.Count
If Rng.Rows(i).Hidden = False Then '行が現れているものだけ
For j = 1 To Rng.Columns.Count
t = Application.Clean(Rng.Cells(i, j).Text) 'バイナリのゴミが入るのを防ぐ
t = VBA.Trim$(t) '両側の空白を取り除く
t = Replace(t, Chr(34), "") '「"」を除く
buf = buf & DELIM & t
Next j
buf = buf & vbCrLf
End If
Next
Else
buf = VBA.Trim$(Rng.Value)
End If
End If
With CB
.SetText buf
.PutInClipboard
.GetFromClipboard
buf2 = .GetText
Beep
End With
ErrHandler:
If Err <> 0 Then
MsgBox Err.Description, vbExclamation
End If
End Sub
No.5
- 回答日時:
私が昔書いたコードとよく似ていますが、これは定番ですよね。
クリップボードの研究はある程度しましたが、DataObject は、簡易型ですが、非常に脆弱です。本格的なものもありますが、大げさになりがちです。
私個人は、以下のようなマクロは使わないのは、そのメモリ空間が少ないからなのです。自由に使うには、Win APIを使うのがよいかと思います。
提示されたコードの中では、 buf As String のデータ型が少し問題があるのかなって思います。
> If TypeName(Selection) = "Range" Then '選択の範囲
これをつけるのが一般的ですが、その後、私は、配列に代入してしまっています。
'//
Sub Setting_Keys()
'ショートカットキーに割り付けます。
'(Workbook_Open, Auto_Openに入れると良い)
Application.OnKey "^+1", "MyClipBoard" 'Ctrl +Shift+ 1(任意)
End Sub
Sub myClipBoard()
Dim buf As Variant, buf2 As String
Dim x As Variant, t As Variant
Dim i As Long, j As Long
Dim CB As Object
Const DELIM As String = " " 'デリミタ
Const CLSID As String = "1C3B4210-F441-11CE-B9EA-00AA006B1A69"
Set CB = GetObject("new:" & CLSID)
If TypeName(Selection) = "Range" Then
x = Selection.Value
If IsArray(x) Then '配列かそうでないかの分離
For i = 1 To UBound(x)
For j = 1 To UBound(x, 2)
t = Application.Clean(x(i, j)) 'バイナリのゴミが入るのを防ぐ
t = Replace(t, Chr(34), "") '「"」を除く
buf = buf & DELIM & x(i, j)
Next j
buf = buf & vbCrLf
Next
Else
buf = x
End If
Else
Exit Sub
End If
With CB
.SetText buf
.PutInClipboard
.GetFromClipboard
buf2 = .GetText
Beep
End With
End Sub
コードありがとうございます。ダブルクォーテーション無しでのテキストエディッタへの貼付けが出来ました。
もう一つなんですが、テーブルでソートしたデーターの場合は、表示していない行を含めたすべてが貼りつきます。
これを、ソートして選択したもの(アクティブにした複数セル)だけのデーターにはならないのでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
Excelでcsvやtxtで保存する時にダブルクォートが勝手に付く
Excel(エクセル)
-
Excelに、ダブルクォーテーションで始まる文字列を貼り付けると、ダブルクォーテーションが消えること
Excel(エクセル)
-
エクセルで文字列をtxtファイルに変換すると"がつく
Excel(エクセル)
-
-
4
【VBA】エクセルで選択した範囲の値のみをクリップボードにコピーするコードについて
Excel(エクセル)
-
5
エクセルでエラーが出て困っています。
Excel(エクセル)
-
6
エクセルVBAでセル範囲のデータをクリップボードに
その他(Microsoft Office)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
- ・ゆるやかでぃべーと タイムマシンを破壊すべきか。
- ・歩いた自慢大会
- ・許せない心理テスト
- ・字面がカッコいい英単語
- ・これ何て呼びますか Part2
- ・人生で一番思い出に残ってる靴
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・初めて自分の家と他人の家が違う、と意識した時
- ・単二電池
- ・チョコミントアイス
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
i=cells(Rows.Count, 1)とi=cel...
-
【Excel】指定したセルの名前で...
-
【Excel VBA】指定行以降をクリ...
-
ExcelVBAを使って、値...
-
Excelで指定した日付から過去の...
-
特定のセルが空白だったら、そ...
-
VBSでエクセル内の行数を取得す...
-
特定の文字を条件に行挿入とそ...
-
連続する複数のセル値がすべて0...
-
vba 隣のセルに値がある行だけ...
-
VBAでセル同士を比較して色付け
-
EXCELのVBA-フィルタ抽出後の...
-
Excelのプルダウンで2列分の情...
-
VBA コピーして次の値まで貼り...
-
Book1のセルへ別Book(Book2)...
-
Excel VBA、 別ブックの最終行...
-
【VBA】指定したセルと同じ値で...
-
DataGridViewでコードで値を入...
-
VBからEXCELのセルの値を取得す...
-
VBA ユーザーフォーム ボタンク...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
i=cells(Rows.Count, 1)とi=cel...
-
ExcelVBAを使って、値...
-
【Excel VBA】指定行以降をクリ...
-
特定のセルが空白だったら、そ...
-
EXCELで変数をペーストしたい
-
Excelで指定した日付から過去の...
-
VBAの間違い教えて下さい
-
【Excel】指定したセルの名前で...
-
Excelのプルダウンで2列分の情...
-
エクセルVBAでコピーして順...
-
Excel vbaで特定の文字以外が入...
-
Excel VBA、 別ブックの最終行...
-
【VBA】指定したセルと同じ値で...
-
特定の文字を条件に行挿入とそ...
-
TODAY()で設定したセルの日付...
-
screenupdatingが機能しなくて...
-
VBA初心者です。次のVBAコード...
-
指定した条件で行セルを非表示...
-
VBAでセルをクリックする回...
-
DataGridViewの各セル幅を自由...
おすすめ情報