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囲碁:万波奈穂先生に捧ぐ


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

import文(パッケージ・モジュールのインポート)|Python入門(9月24日)
例外処理(try文)とexception一覧|Python入門(9月23日)
リスト内包表記|Python入門(9月22日)
Pythonの引数は参照渡しだが・・・|Python入門(9月21日)
lambda(ラムダ式、無名関数)と三項演算子|Python入門(9月20日)
関数内関数(関数のネスト)とスコープ|Python入門(9月18日)
関数の定義(def文)と引数|Python入門(9月18日)
組み込み関数一覧|Python入門(9月17日)
辞書(dict型)|Python入門(9月16日)
入力規則への貼り付けを禁止する|VBA技術解説(9月16日)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.マクロって何?VBAって何?|VBA入門
5.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
6.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
7.繰り返し処理(For Next)|VBA入門
8.セルに文字を入れるとは(Range,Value)|VBA入門
9.とにかく書いてみよう(Sub,End Sub)|VBA入門
10.マクロはどこに書くの(VBEの起動)|VBA入門




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


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



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