三流君 ken3のmemo置き場

メモ置き場、保管庫として利用。まとまっていませんがヨロシク

挨拶・自己紹介:
失敗続きのAB型の変わり者 :三流プログラマー Ken3です
フリーのエンジニア・個人事業主です・・と書くと聞こえはイイが(それとなくカッコよく聞こえるが)、 現在は小さな案件の受注請負 と 短期派遣 で 日々つつましく?ほそぼそと暮らしてます。
(※詳細は[三流君 三流プログラマーとは?]を見てください)


広告:


[記事一覧、バックナンバーを見る]

クリップボード から テキスト取得して選択セルに追記してみた

人力検索↓で久々に回答してみた。
q.hatena.ne.jp
※中途半端なコードなのにOKをもらってしまった。

VBA クリップボードで検索する
とイロイロなページがヒットします。
ExcelのVBAで、クリップボードのデータ形式を確認する。〜パソコンの小技・備忘録
Office TANAKA - Excel VBA Tips[クリップボードを操作する(1)]
クリップボードとデータのやりとりをする:Excel VBA|即効テクニック|Excel VBAを学ぶならmoug

上記を参考にして、

参照設定で
Microsoft Forms 2.0 Object Library
と言われるが、見つからない ぉぃぉぃ

で、フォームを挿入すると簡単と書いてあったので、
一つフォームを挿入する

参照設定だけ、下記の動画を見てください。
Excel VBA クリップボード 複数選択セルに貼り付け はてな 回答 テスト動画 2017/08/02 【三流君】 - YouTube
www.youtube.com
↑参照設定とテスト動画。

Sub はてな回答テスト20170802()

    Dim CB As Variant 'クリップボードにはさまざまな形式なので
    Dim strADDTEXT As String  'クリップボードから追記するテキスト保管
    Dim selectRANGE As Range  '選択範囲
    Dim n As Integer  'N番目
    Dim y As Integer  '行
    Dim x As Integer  '列
    
    'クリップボード内のデータ種類を判断
    CB = Application.ClipboardFormats
    
    If CB(1) = -1 Then
        Debug.Print "クリップボードには何も入っていません。"
        Exit Sub
    End If

    'テキスト形式か?
    If CB(1) = xlClipboardFormatText Then
        'テキストデータを取り出す
        With New MSForms.DataObject
            .GetFromClipboard    ''変数のデータをDataObjectに格納する
            strADDTEXT = .GetText 'テキストを取得
            Debug.Print strADDTEXT
            '選択されているセルに対して処理を行う
            Set selectRANGE = ActiveWindow.Selection
            '複数セル、範囲もあるのでループさせる
            For n = 1 To selectRANGE.Areas.Count  '※nは1から
                'セルが範囲選択されている可能性があるので、
                Debug.Print n & " " & selectRANGE.Areas(n).Address
                Debug.Print selectRANGE.Areas(n).Rows.Count
                Debug.Print selectRANGE.Areas(n).Columns.Count
                For y = 1 To selectRANGE.Areas(n).Rows.Count  '行のループ
                    For x = 1 To selectRANGE.Areas(n).Columns.Count '列のループ
                        Debug.Print selectRANGE.Areas(n).Cells(y, x).Address
                        Debug.Print selectRANGE.Areas(n).Cells(y, x).Value
                        selectRANGE.Areas(n).Cells(y, x).Value = selectRANGE.Areas(n).Cells(y, x).Value & strADDTEXT
                    Next x
                Next y
            Next n
        End With
    End If

End Sub

↑のコードを貼り付けて、テストしてみてください。
Debug.Print は 必要ないので、消してください。

動画の後半で、テスト時、Excelのセルをコピーしてクリップボードに入れた場合、
テキストとして 反応しないので、バグってます。

参照設定だけ、下記の動画を見てください。
※冒頭の動画と一緒です・・・
www.youtube.com
↑参照設定とテスト動画。




三流君へ メッセージを送る

全ての質問に答えることはできませんが、
ダメもとで、気軽に質問、感想、メッセージを送ってくださいね・・・

感想や質問・要望・苦情など 三流君へメッセージを送る。
下記のフォームからメッセージを送ることができます。


あなたのお名前(ニックネーム):さん
返信は?:

アドレス:に返事をもらいたい
感想や質問↓:


(感想や質問・要望・苦情はHPで記事に載せることがあります。)
例:[XXXXさんへ回答例]←みたいに回答していたり...


Ken3 ホームページ 目次

分類:HPを大きく分けると4つの柱(分類)です。
・[Excel/Access VBA]の解説
・[ASP(Active Server Pages)]の解説。
・[元コンビニ店長時代の話]が弟に巻き込まれ、失敗した脱サラ、畑違い?の仕事で失敗。
・[プログラマーの愚痴]では、あまり見せたくない三流プログラマーの内面かな。
三流君を踏み台にする
主に上記4つの分類でHP作成やメルマガの発行を行ってます。
※更新頻度が落ちていて情報の鮮度が悪いです。

三流解説動画の再生リスト
https://www.youtube.com/user/ken3video/playlists

本当に三流なんです(笑):たまにスゴイですねなんて言われることもありますが、
真実は→ [三流君の真実は...] ←を初めに見てくださるとわかると思います。
(からくりは、成功例↑しか載せてなくて ヒドイ失敗例はお蔵入り迷宮入りが多かったりします)