VBAの初心者です。
エクセル2016を使っておりますが,選択した範囲(複数セル)の値のみをクリップボードにコピーするマクロをご教示願います。
検索すると,以下のものが出てきますが,走らせると止まってしまいます。
https://qiita.com/tukiyo3/items/0d50f2834fb5098b …
Sub copy_e6()
'
' copy_e6 Macro
'
Dim myDO As New DataObject
myDO.SetText Range("E6").Value
myDO.PutInClipboard
End Sub
No.3ベストアンサー
- 回答日時:
横から失礼します
少し難しい回答かもしれませんが
参照設定については 後にして 貼り付け先(使用用途は)どこなのでしょう
>値のみをクリップボードにコピーする
サンプルは単セルですがExcelのセル範囲を選択して実行している場合
列方向 vbTab 行方向 vbCrlfが必要になるのではないかと思います
(各値をただ繋げるなら不要ですが)
以下サンプル
実行時参照でDataObjectを使っていますが エラーになるかも知れません
Sub copy_e6()
'
' copy_e6 Macro
'
Dim ary As Variant
ary = Selection.Value '選択範囲の値を一旦配列に格納
' Dim myDO As New DataObject
Dim myDO As Object
Set myDO = CreateObject("new:{1C3B4210-F441-11CE-B9EA-00AA006B1A69}")
Dim i As Long, j As Long
Dim strBuf As String
For i = 1 To UBound(ary, 1)
For j = 1 To UBound(ary, 2)
strBuf = strBuf & ary(i, j) & vbTab
Next
strBuf = Left(strBuf, Len(strBuf) - 1) '右のタブコードを削除
strBuf = strBuf & vbCrLf '改行コードを付加
Next
myDO.SetText strBuf
myDO.PutInClipboard
Set myDO = Nothing
End Sub
配列に入れている理由
オブジェクトやコレクションをループするEachのループ方向は信頼できないと聞いたことがあるので カラム>>行 の順序を確定する為
参照設定については こちらを参考にしてみてください
NJ-CLUCKER
https://nj-clucker.com/excel/references-ms-forms …
参照設定が正しく出来た場合は(このままでも良いですが)
Dim myDO As New DataObject の方を使用して
Dim myDO As Object
Set myDO = CreateObject("new:{1C3B4210-F441-11CE-B9EA-00AA006B1A69}")
は削除してください
No.2
- 回答日時:
MSFormsライブラリが読み込まれていない可能性があります。
以下の手順に従って、ライブラリを読み込んでから、コードを実行してください。Excelを開いて、Visual Basic Editorを開きます。
[ツール]メニューから[参照設定]をクリックします。
[参照設定]ダイアログボックスで、[Microsoft Forms 2.0 Object Library]を選択します。
[OK]ボタンをクリックして、ダイアログボックスを閉じます。
以下は、選択範囲の値と数式を両方コピーするために改良されたコードです。
Sub CopySelectedValuesAndFormulasToClipboard()
Dim dataObj As New MSForms.DataObject
Dim selectedRange As Range
Dim cell As Range
Dim outputString As String
Set selectedRange = Selection
' Loop through each cell in the selected range and append its value or formula to the output string.
For Each cell In selectedRange.Cells
If cell.HasFormula Then
outputString = outputString & cell.Formula & vbTab
Else
outputString = outputString & cell.Value & vbTab
End If
Next cell
' Remove the trailing tab character from the output string.
outputString = Left(outputString, Len(outputString) - 1)
' Copy the output string to the clipboard.
dataObj.SetText outputString
dataObj.PutInClipboard
End Sub
このコードでは、HasFormulaプロパティを使用して、セルが数式を持つかどうかをチェックし、必要に応じて値または数式をコピーします。コードを実行する前に、選択範囲内に数式が含まれていることを確認してください。
ありがとうございます。
しかし,「[参照設定]ダイアログボックスで、[Microsoft Forms 2.0 Object Library]を選択します。」とのことですが,[Microsoft Forms 16.0 Object Library]はあっても,[Microsoft Forms 2.0 Object Library]が選択項目としてありません。
[Microsoft Forms 16.0 Object Library]にチェックをした状態で,書いていただいたコードを走らせると,前回と同じく「コンパイルエラー:ユーザ定義型は定義されていません」と出て止まってしまいます。
何がダメなのでしょうか。。
ご教示いただけると幸いです。
No.1
- 回答日時:
Sub CopySelectedValuesToClipboard()
Dim dataObj As New MSForms.DataObject
Dim selectedRange As Range
Dim cell As Range
Dim outputString As String
Set selectedRange = Selection
' Loop through each cell in the selected range and append its value to the output string.
For Each cell In selectedRange.Cells
outputString = outputString & cell.Value & vbTab
Next cell
' Remove the trailing tab character from the output string.
outputString = Left(outputString, Len(outputString) - 1)
' Copy the output string to the clipboard.
dataObj.SetText outputString
dataObj.PutInClipboard
End Sub
Alt + F8を押して、マクロの実行ウィンドウを開きます。
CopySelectedValuesToClipboardを選択して、実行をクリックします。
クリップボードに選択した範囲の値がコピーされます。
注意:このマクロは、選択範囲内のすべてのセルの値をクリップボードにコピーします。セルに数式が含まれている場合は、その数式がコピーされます。数式の結果のみをコピーする場合は、セルの値を手動でコピーする必要があります。
ありがとうございます。
申し訳ないのですが,選択範囲には数式が多数含まれており,それについても値でコピーしたいです。
また,教えていただいたコードを実行してみましたがうまく動きません。
「コンパイルエラー:ユーザ定義型は定義されていません」と表示されます。そのときに,2行目の「dataObj As New MSForms.DataObject」が選択された状態になっています。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) VBAコードを張り付け後のエクセルの進め方 2 2023/02/07 18:24
- Excel(エクセル) VBA 特定の列に入っているテキストをコピペ 2 2023/06/14 11:24
- Visual Basic(VBA) 複数シート一括作成後に、特定範囲の数式は値で貼り付けしたい 3 2022/10/07 11:18
- Visual Basic(VBA) Excelのマクロコードについて教えてください。 1 2022/03/27 13:25
- Excel(エクセル) VBA カゥントで数値の範囲を規制 1 2022/05/20 06:20
- Visual Basic(VBA) Excel VBA キーワードから列を取得して、さらに空欄行を非表示にする 3 2022/10/21 22:49
- Visual Basic(VBA) エクセルVBAのコードで質問です。 下のコードはJ16の文字列をB3を起点とする範囲から探して、見つ 5 2023/04/07 11:07
- Excel(エクセル) エクセルVBA、ファイル名をセルの値で保存の方法を教えてください。 おそれいります。こちらで数々のエ 6 2023/06/30 22:17
- Visual Basic(VBA) データのある範囲を選択するVBAについて 2 2022/09/03 00:20
- Excel(エクセル) VBAのエラーが直せません 4 2023/06/12 22:10
このQ&Aを見た人はこんなQ&Aも見ています
-
【お題】NEW演歌
【大喜利】 若い人に向けたことは分かるけど、それはちょっと寄せ過ぎて変になってないか?と思った演歌の歌詞
-
秘密基地、どこに作った?
小さい頃、1度は誰もが作ったであろう秘密基地。 大人の今だからこそ言える、あなたの秘密基地の場所を教えてください!
-
忘れられない激○○料理
これまでに食べたもののなかで、もっとも「激○○」だった料理を教えて下さい。 激辛、でも激甘でも。 激ウマ、でも激マズでも。
-
牛、豚、鶏、どれか一つ食べられなくなるとしたら?
牛肉、豚肉、鶏肉のうち、どれか一種類をこの先一生食べられなくなるとしたらどれを我慢しますか?
-
タイムマシーンがあったら、過去と未来どちらに行く?
20XX年、ついにタイムマシーンが開発されました。 あなたは過去に行く? それとも未来? タイムマシーンにのって、どこに行って、何をしたいか教えてください!
-
エクセルVBAでセル範囲のデータをクリップボードに
その他(Microsoft Office)
-
【VBA】エクセルで値のみクリップボードにコピーするコードについて(貼り付け時の空白削除)
Visual Basic(VBA)
-
セルの値だけクリップボードにコピーするマクロ
Visual Basic(VBA)
-
-
4
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
5
vba クリップボードクリアについて教えてください
その他(プログラミング・Web制作)
-
6
EXCEL VBAで全選択範囲の解除
Excel(エクセル)
-
7
エクセルの複数データーをダブルクォーテーションなしでコピー貼付けしたい。テキストエディタで使用
Microsoft ASP
-
8
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
9
worksheetFunctionクラスのVlookupプロパティを取得できません エラーへの対応
Visual Basic(VBA)
-
10
エクセルの複数のセルを一括で絶対参照にする方法
Excel(エクセル)
-
11
VBAコード記述に際して、コード全体を自動的にインデント付ける方法
Access(アクセス)
-
12
ユーザーフォームを表示中にシートの操作をさせるには
Excel(エクセル)
-
13
エクセルVBA/イベント発生でコピペ不能はなぜ?
Excel(エクセル)
-
14
EXCELで変数をペーストしたい
その他(プログラミング・Web制作)
-
15
ListViewで、非表示列って作れますか?
Visual Basic(VBA)
-
16
Excelの入力規則で2列表示したい
Excel(エクセル)
-
17
VBAにてメッセージボックスを最前面に表示させる
その他(プログラミング・Web制作)
-
18
EXCEL/VBA 変数の値をクリップボードにコピーする方法
Visual Basic(VBA)
-
19
VBマクロ 色の付いたセルを含む行をコピーしたい。
Visual Basic(VBA)
-
20
UserForm1.Showでエラーになります。
工学
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
- ・お風呂の温度、何℃にしてますか?
- ・とっておきの「まかない飯」を教えて下さい!
- ・2024年のうちにやっておきたいこと、ここで宣言しませんか?
- ・いけず言葉しりとり
- ・土曜の昼、学校帰りの昼メシの思い出
- ・忘れられない激○○料理
- ・あなたにとってのゴールデンタイムはいつですか?
- ・とっておきの「夜食」教えて下さい
- ・これまでで一番「情けなかったとき」はいつですか?
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
首吊りどこ締めるの
-
白血球が多いとどんな心配があ...
-
彼女のことが好きすぎて彼女の...
-
EXCELで条件付き書式で空白セル...
-
エクセルで数式の答えを数値と...
-
EXCELで式からグラフを描くには?
-
2つの数値のうち、数値が小さい...
-
小数点以下を繰り上げたものを...
-
値が入っているときだけ計算結...
-
リンク先のファイルを開かなく...
-
エクセル指定した範囲からラン...
-
MIN関数で空白セルを無視したい...
-
EXCELの条件付き書式で数式を空...
-
風俗店へ行く前のご飯
-
これって喉仏ですか? 私は女性...
-
エクセルで空白セルを含む列の...
-
至急!尿検査前日にオナニーし...
-
エクセルのラベルの値(文字列...
-
エクセルでエラーが出て困って...
-
ワードのページ番号をもっと下...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
首吊りどこ締めるの
-
彼女のことが好きすぎて彼女の...
-
白血球が多いとどんな心配があ...
-
検便についてです。 便は取れた...
-
精液の落とし方を教えてください
-
勃起する時って痛いんですか? ...
-
2つの数値のうち、数値が小さい...
-
エクセル指定した範囲からラン...
-
エクセルで数式の答えを数値と...
-
これって喉仏ですか? 私は女性...
-
小数点以下を繰り上げたものを...
-
EXCELで条件付き書式で空白セル...
-
EXCELで式からグラフを描くには?
-
イタリアから帰国する際、肉製...
-
エクセルのラベルの値(文字列...
-
Excel 0目標に対して数字があ...
-
ある範囲のセルから任意の値を...
-
風俗店へ行く前のご飯
-
リンク先のファイルを開かなく...
-
甲状腺が腫れているが血液検査...
おすすめ情報