VBAサンプル集
アメブロの記事本文をVBAでバックアップする№1

ExcelマクロVBAの実用サンプル、エクセルVBA集と解説
最終更新日:2016-10-30

アメブロの記事本文をVBAでバックアップする№1

後日追記

アメブロの仕様変更が度々あり、ここで紹介しているコードで取得できないものもあります、
いつ仕様変更されるかわかりませんので、都度変更するのは結構大変です。
あくまで、WEBページの取得技術方法として参考にしてください。



アメブロにはバックアップ機能がありません。

間違って削除・更新してしまう事もありますので、なんとかバックアップを取っておきたいところです。

ブラウザで記事を表示して、ローカルに保存すれば良いのですが、ちょっと面倒です。

そして、記事本文以外も全てくっついてきてしまいますので、後々の処置が困ります。

ExcelマクロVBAを使えば、この記事本文のみのバックアップも可能です。

VBAでInternetExplorerを操作し、中の情報を取得します。

ただし、アメブロへのログイン機能は付けていませんので、


事前にInternetExplorerアメブロにログインしておいて下さい。、
(ログインしたら、InternetExplorerは閉じてしまって良いです)

まず、以下のようなシートを用意して下さい。

マクロ VBA サンプル画像

色合いは、なんでもかまいません。

A列には、記事エントリーのIDが入ります。
IDは数値なのですが、後々の扱いやすさを考慮して、表示形式を「文字列」にして下さい。

標準モジュールを追加して、

まずは、以下を貼り付けてください。

Declare Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long)
'64bit版のExcelの場合は、以下のようにPtrSafeを付けて下さい。
'Declare PtrSafe Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long)

Sub untilReady(objIE As Object)
  Dim starttime As Date
  starttime = Now()
  Do While objIE.Busy = True Or objIE.ReadyState <> READYSTATE_COMPLETE
    Sleep 100
    DoEvents
    If Now() > DateAdd("S", 10, starttime) Then
      Exit Do
    End If
  Loop
End Sub



これは、


InternetExplorerで指定のURLを開いた時に、すべて読み込まれるまで待つためのプロシージャーです。

InternetExplorerにURLを指定しても、しばらく進捗バーが進むのを待ちますよね、それに相当します。

Do While objIE.Busy = True Or objIE.ReadyState <> READYSTATE_COMPLETE

この部分がそうです。

Busy、または、COMPLETE以外の間は待つということです。

もし応答なしになってしまうと、永久にDo~Loopから抜けませんので、

If Now() > DateAdd("S", 10, starttime) Then

これで、10秒待ってもダメだったら抜けるようにしています。

では、本題のバックアップするコードに入ります。

いや、その前に、まずは記事の一覧を取得します。

アメブロの記事本文をVBAでバックアップする №1 №2 №3 №4 №5 №6



同じテーマ「マクロVBAサンプル集」の記事

アメブロの記事本文をVBAでバックアップする№1
数独(ナンプレ)を解くVBAに挑戦№1
数独(ナンプレ)を解くアルゴリズムの要点とパフォーマンスの検証№1
ナンバーリンク(パズル)を解くVBAに挑戦№1
ナンバーリンクを解くVBAのパフォーマンス改善№1
オセロを作りながらマクロVBAを学ぼう
他ブックへのリンクエラーを探し解除
Excelシートの複雑な計算式を解析するVBA
Excel将棋:マクロVBAの学習用(№1)
Excel囲碁:万波奈穂先生に捧ぐ
Excel囲碁:再起動後も続けて打てるように改造


新着記事NEW ・・・新着記事一覧を見る

新旧マスタの差異比較|Power Query(M言語)入門(2023-02-28)
有効な最新単価の取得|Power Query(M言語)入門(2023-02-26)
有効な最新単価の取得|Power Query(M言語)入門(2023-02-21)
グルーブ内の最小・最大|Power Query(M言語)入門(2023-02-17)
2つのテーブルのマージ|Power Query(M言語)入門(2023-02-15)
「売上」が数値の行のみ取り込む|Power Query(M言語)入門(2023-02-13)
A列のヘッダー名を変更する|Power Query(M言語)入門(2023-02-11)
CSVのA列が日付の行だけを取り込む|Power Query(M言語)入門(2023-02-10)
列数不定のCSVの取り込み|Power Query(M言語)入門(2023-02-09)
別ブックの最終シートの取り込み|Power Query(M言語)入門(2023-02-08)


アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.繰り返し処理(For Next)|VBA入門
5.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
6.マクロって何?VBAって何?|VBA入門
7.並べ替え(Sort)|VBA入門
8.Excelショートカットキー一覧|Excelリファレンス
9.エクセルVBAでのシート指定方法|VBA技術解説
10.Range以外の指定方法(Cells,Rows,Columns)|VBA入門




このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。



このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
本文下部へ