
セルをコピーしてメモ帳などのテキストエディタに貼り付けると、””(ダブルクォーテーション)で囲まれますよね。
現在は、テキストエディタでデーターを使用するときに、複数セルを選択コピーして、ワードに張り付けて再度コピーして利用していますが。
複数のアクティブセルをコピーして、ワードに貼付け、それをコピーする操作をマクロにできないでしょうか。テキストエディタで使用するため。
*ダブルクォーテーションなしでテキストエディタに使用できるならその他の方法でもよいのですが・・・
何度も同じ作業をするために、ワードはすべて選択で貼付け、コピーしています。
複数のアクティブセルは、行・列は変化し、選択セル数は変化します。
データーはエクセルのシートのテーブルでソートしたあるデーターを利用するため。
又、あるサイトで「エクセルのコピー時にダイレクトにクリップボード操作するマクロ」を見つけましたが、アクティブセルのみコピーで、複数セルに対応してないとのこと
コード
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で質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) 【VBA】エクセルで選択した範囲の値のみをクリップボードにコピーするコードについて 3 2023/03/08 17:41
- Visual Basic(VBA) サブフォルダ(データ)にある複数の.xlsxファイルのSheet3のA2セルの値で01から左側をB2 2 2022/08/14 15:46
- Excel(エクセル) VBA 特定の列に入っているテキストをコピペ 2 2023/06/14 11:24
- Excel(エクセル) Excel フィルタ後のコピー貼付けと可視セルの関係について 3 2023/02/07 16:42
- Visual Basic(VBA) 複数csvを横に追加していくマクロについて 2 2023/04/25 09:19
- Visual Basic(VBA) 別ブックからシートのコピー 3 2022/04/01 20:07
- Visual Basic(VBA) vbaエクセルマクロ RemoveDuplicatesについて RemoveDuplicatesを使 3 2023/02/28 01:13
- Visual Basic(VBA) 改行ごとに行を追加し、数量を分割 4 2023/07/11 16:39
- Excel(エクセル) 2つのVBAを一緒にしたら機能しなくなりました(エクセル) 7 2022/06/02 12:41
- その他(Microsoft Office) マクロVBAについて 1 2022/09/06 18:12
このQ&Aを見た人はこんなQ&Aも見ています
-
マクロから出力されるcsvのダブルコーテーションをなくしたい。
Visual Basic(VBA)
-
VBAでメモ帳にコピペをしたいのですが…
PowerPoint(パワーポイント)
-
Excelからテキストへのコピーペースト
その他(Microsoft Office)
-
-
4
エクセルで文字列をtxtファイルに変換すると"がつく
Excel(エクセル)
-
5
Excelでcsvやtxtで保存する時にダブルクォートが勝手に付く
Excel(エクセル)
-
6
Excelに、ダブルクォーテーションで始まる文字列を貼り付けると、ダブルクォーテーションが消えること
Excel(エクセル)
-
7
エクセルの"の削除方法を教えてください。
その他(Microsoft Office)
-
8
VBA メモ帳で ” を消去する方法
Excel(エクセル)
-
9
レジストリの変更が反映されない
Windows 10
-
10
【VBA】エクセルで選択した範囲の値のみをクリップボードにコピーするコードについて
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excelで指定した日付から過去の...
-
エクセルvbaで、別シートの最下...
-
セルに貼り付けた画像の上から...
-
VBA初心者です。結合セルを保持...
-
ExcelVBAを使って、値...
-
Excel vbaで特定の文字以外が入...
-
VBAでセルをクリックする回...
-
特定のセルが空白だったら、そ...
-
エクセルvba:自己セルの情報取...
-
最後のデータ行の任意のセルの...
-
Excle VBA Findメソッドについて
-
VBA初心者です。 VBAで行単位で...
-
エクセルVBAでのセル番地取得プ...
-
excelで置換をしたいんですが
-
SPREADでセルの連結
-
Excel2003 複数セル1列の入力済...
-
エクセルVBAの”TextToColumns”...
-
【VBA】指定したセルと同じ値で...
-
【Excel VBA】指定行以降をクリ...
-
TODAY()で設定したセルの日付...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ExcelVBAを使って、値...
-
Excelで指定した日付から過去の...
-
エクセルvbaで、別シートの最下...
-
i=cells(Rows.Count, 1)とi=cel...
-
特定のセルが空白だったら、そ...
-
Excelのプルダウンで2列分の情...
-
【Excel VBA】指定行以降をクリ...
-
任意フォルダから画像をすべて...
-
VBAでセルをクリックする回...
-
”戻り値”が変化したときに、マ...
-
VBA実行後に元のセルに戻りたい
-
Excel vbaで特定の文字以外が入...
-
【VBA】シート上の複数のチェッ...
-
Excel VBA マクロ ある列の最終...
-
Excel VBAで、 ヘッダーへのセ...
-
DataGridViewの各セル幅を自由...
-
VBからEXCELのセルの値を取得す...
-
EXCELのVBA-フィルタ抽出後の...
-
VBAでセル同士を比較して色付け
-
Application.Matchで特定行の検索
おすすめ情報