2017年08月 / 07月≪ 12345678910111213141516171819202122232425262728293031≫09月

インフォメーション

FC2ブログで画像等を一括アップロードするソフトを地味に配布してます。
FC2ブログ用ファイルアップロードの最新版はこちら
(ベクター)FC2ブログ用ファイルアップロード

--.--.-- (--)

スポンサーサイト

上記の広告は1ヶ月以上更新のないブログに表示されています。
新しい記事を書く事で広告が消せます。


 |  --:--  |  スポンサー広告  |  Top↑

2009.03.26 (Thu)

FC2ブログでファイルを一括アップロード【更新】 - UWSC

どうやらこのFC2ブログのファイルのアップロードに一括アップロードが付いたらしい。
いつの間に?!気が付かなかった。

一括といっても結局1回で何個か選択できるだけで、あまり変わらないのは確かだ。

そしてその一括アップロードが出来るようになったので、画面構成もちょっと変わったみたいで
Vineさんからファイルパスが入らなくなったとコメントを頂いたので早速修正しました。
Vineさんのブログのインフォメーションに紹介していただきました。有難う御座います。)

使い方は以前と同じ
1.USERIDにFC2ブログのユーザーID、PASSWORDにパスワードを入れるか、IEでFC2ブログにログインしておく(ログイン状態であればID,パスワードは不要)
2.任意の場所にフォルダを作成し(D:\Temp\updirとか)、アップロードしたいファイルを作成したフォルダに入れる
3.以下のスクリプトの「SRC_DIR」に2.で作成したフォルダのパスを入れる
4.UWSCで以下のスクリプトを実行

注)指定したフォルダ内のすべてのファイルをアップロードしようとするので、アップロードし終わったファイルは削除してください

FC2ブログ一括アップロード.txt

↑拡張子を.UWSに変更して使用してください

↓中身



// *****************
// 基本設定
// *****************
PUBLIC USERID = "user"
PUBLIC PASSWORD = "pass"
PUBLIC SRC_DIR = "D:\Temp\updir" //アップロードフォルダ

// *****************
// 設定内容の確認
// *****************
ifb SRC_DIR = "" then
msgbox("アップロード対象フォルダが設定されていません")
exit
endif

try
// ファイルの取得
filecount = GetDir(SRC_DIR)
// アップロードするファイルがない場合終了
ifb filecount = 0 then
msgbox("アップロード対象ファイルが見つかりません。<#cr>" + SRC_DIR)
exit
endif
except
// 例外が発生したら終了
msgbox("エラー:" + TRY_ERRMSG)
exit
endtry

// IEのバージョン取得
ws = CreateOleObj("Wscript.Shell")
Version = token(".", ws.RegRead("HKLM\Software\Microsoft\Internet Explorer\Version"))


PUBLIC IE = CreateOLEObj("InternetExplorer.Application")
PUBLIC ID = HNDTOID(ie.hwnd)

// *****************
// メイン処理
// *****************
IE.Visible = true;
// FC2ブログhpを開く
IE.Navigate("http://blog.fc2.com/");

// IE7対応
IFB Version = 7 THEN
IE.Quit
SLEEP(1)
objShell = CreateOLEObj("Shell.Application")
IE = objShell.Windows.Item(objShell.Windows.Count - 1)
// FC2ブログhpを開く
IE.Navigate("http://blog.fc2.com/")
ENDIF

REPEAT
SLEEP(1)
UNTIL !IE.busy AND IE.readystate=4

// ログインフォームが存在する場合
ifb IE.document.forms["login"] > 0 then
frm = IE.document.forms["login"]
IE.document.getElementById("acid").value = USERID
IE.document.getElementById("passwd").value = PASSWORD
frm.submit()
else
IE.Navigate("http://blog.fc2.com/?admin")
endif

REPEAT
SLEEP(1)
UNTIL !IE.busy AND IE.readystate=4


ifb pos("fc2.com/control.php", IE.LocationURL) = 0 then
// ログインできなかったら終了
msgbox("ログインできませんでした。")
exit
endif

// アップロード画面を開く
tmp = Copy(IE.LocationURL, 1, POS("control.php", IE.LocationURL) + Length("control.php") - 1)
IE.Navigate(tmp + "?mode=control&process=upload")

REPEAT
SLEEP(1)
UNTIL !IE.busy AND IE.readystate=4


// ファイル数分アップロード
for i = 0 to filecount - 1
// フォーム取得
frm = IE.document.forms["upload"]
// ファイルパス
filepath = SRC_DIR + "\" + GETDIR_FILES[i]

// 最小化してるとファイル名が入らないので戻す
if STATUS(ID, ST_ICON) then CTRLWIN(ID, NORMAL)

ifb Version = 6 then
// ファイル入力ボックスにフォーカスを当てる
frm.upfile[0].focus()
// sendstrで入力
sendstr(ID, filepath)
endif

ifb Version = 7 then
KBD(VK_CTRL, DOWN)
IESETDATA(IE, filepath, "upfile[]", "", 0)
KBD(VK_CTRL, UP)
endif

inputs = frm.getElementsByTagName("input")
// type=submitを探す
for j = 0 to inputs.length - 1
ifb inputs.item(j).type = "submit" then
// 見つかったらクリックしてアップロード
inputs.item(j).click
break
endif
next

REPEAT
SLEEP(1)
UNTIL !IE.busy AND IE.readystate=4
next

msgbox("完了")



複数アップロードが出来るようになったことで、ファイル入力ボックスの名前が
"upfile"->"upfile[]"に変わったみたい。
変化はそれくらいかな。

家の環境(Vista+IE7)でのみ動作確認したので、
IE6の場合もちゃんと動くかはまだ確認していません。
スポンサーサイト


 |  01:50  |  UWSC  |  トラックバック(0)  |  コメント(2)  |  Top↑

2008.09.26 (Fri)

FC2ブログでファイルを一括アップロード(英語環境対応) - UWSC

FC2ブログでファイルを一括アップロード - UWSC
このコードを英語環境で動かしたら・・・というコメントをいただき、
ちょうどこのパソコンのVirtualPCにも英語版XPが入っていたので喜び勇んで英語環境対応にしました。
ちゃんと日本語環境でも使えます。

使い方は以前と同じ
1.USERIDにFC2ブログのユーザーID、PASSWORDにパスワードを入れるか、IEでFC2ブログにログインしておく(ログイン状態であればID,パスワードは不要)
2.任意の場所にフォルダを作成し(D:\Temp\updirとか)、アップロードしたいファイルを作成したフォルダに入れる
3.「SRC_DIR」に2.で作成したフォルダのパスを入れる
4.UWSCで以下のスクリプトを実行

注)指定したフォルダ内のすべてのファイルをアップロードしようとするので、アップロードし終わったファイルは削除してください

FC2ブログ一括アップロード.txt


↑拡張子を.UWSに変更して使用してください

↓中身



// *****************
// 基本設定
// *****************
PUBLIC USERID = "user"
PUBLIC PASSWORD = "pass"
PUBLIC SRC_DIR = "D:\Temp\updir" //アップロードフォルダ

// *****************
// 設定内容の確認
// *****************
ifb SRC_DIR = "" then
msgbox("アップロード対象フォルダが設定されていません")
exit
endif

try
// ファイルの取得
filecount = GetDir(SRC_DIR)
// アップロードするファイルがない場合終了
ifb filecount = 0 then
msgbox("アップロード対象ファイルが見つかりません。<#cr>" + SRC_DIR)
exit
endif
except
// 例外が発生したら終了
msgbox("エラー:" + TRY_ERRMSG)
exit
endtry


PUBLIC IE = CreateOLEObj("InternetExplorer.Application")
PUBLIC ID = HNDTOID(ie.hwnd)

// *****************
// メイン処理
// *****************
IE.Visible = true;
// FC2ブログhpを開く
IE.Navigate("http://blog.fc2.com/");

REPEAT
SLEEP(1)
UNTIL !IE.busy AND IE.readystate=4

// ログインフォームが存在する場合
ifb IE.document.forms["login"] > 0 then
frm = IE.document.forms["login"]
IE.document.getElementById("acid").value = USERID
IE.document.getElementById("passwd").value = PASSWORD
frm.submit()
else
IE.Navigate("http://blog.fc2.com/?admin")
endif

REPEAT
SLEEP(1)
UNTIL !IE.busy AND IE.readystate=4


ifb pos("fc2.com/control.php", IE.LocationURL) = 0 then
// ログインできなかったら終了
msgbox("ログインできませんでした。")
exit
endif

// アップロード画面を開く
tmp = Copy(IE.LocationURL, 1, POS("control.php", IE.LocationURL) + Length("control.php") - 1)
IE.Navigate(tmp + "?mode=control&process=upload")

REPEAT
SLEEP(1)
UNTIL !IE.busy AND IE.readystate=4


// ファイル数分アップロード
for i = 0 to filecount - 1
// フォーム取得
frm = IE.document.forms["upload"]
// ファイルパス
filepath = SRC_DIR + "\" + GETDIR_FILES[i]

// 最小化してるとファイル名が入らないので戻す
if STATUS(ID, ST_ICON) then CTRLWIN(ID, NORMAL)

ifb GetIEVersion() = 6 then
// ファイル入力ボックスにフォーカスを当てる
frm.upfile.focus()
// sendstrで入力
sendstr(ID, filepath)
endif

ifb GetIEVersion() = 7 then
KBD(VK_CTRL, DOWN)
IESETDATA(IE, filepath, "upfile")
KBD(VK_CTRL, UP)
endif

inputs = frm.getElementsByTagName("input")
// type=submitを探す
for j = 0 to inputs.length - 1
ifb inputs.item(j).type = "submit" then
// 見つかったらクリックしてアップロード
inputs.item(j).click
break
endif
next

REPEAT
SLEEP(1)
UNTIL !IE.busy AND IE.readystate=4
next

msgbox("完了")

FUNCTION GetIEVersion()
FS = CreateOLEObj("Scripting.FileSystemObject")

// GetFileVersionでIEのバージョンを取得。
//IE.FullNameはiexplore.exeのフルパス
strVersion = FS.GetFileVersion(IE.FullName)

// 6.0.2900...って感じの文字なので、"."より前の肝心な部分だけ数値として取り出す
intVersion = Val(Copy(strVersion, 1, Pos(".", strVersion) - 1))

RESULT = intVersion
FEND


とりあえず動くので、コメントやメッセージは日本語のままです。
修正箇所はIELINK(日本語)->IE.Navigate(URL)に変えたーとか
フォームの取得方法をgetElementsByName->document.forms[]に変えたくらい。

それにしても英語OSで英語版のfc2blogトップページからログインしても、日本語版のblog管理画面になるんだな。
もし英語版の管理画面になるんだとしたら、URLとかの修正が必要になってくるかも。



追加修正
IE7で正しく動かなかったので、IE7でも動くように修正しました。

修正内容はアップロードファイルのパスを入れる動作を修正。
↓これを

// ファイル入力ボックスにフォーカスを当てる
frm.upfile.focus()
// sendstrで入力
sendstr(ID, filepath)


↓これに変えた

KBD(VK_CTRL, DOWN)
IESETDATA(IE, filepath, "upfile")
KBD(VK_CTRL, UP)

元々このtype=fileのボックスにファイルパスを入れる動作は気になっていたところでした。
後者のIESETDATAを使うとクリップボードにファイルパスが入ってしまうのがどうも気になってしまって、
他の方法を探して前者のsendstrで無理やり入れてました。
やっぱIESETDATAで入れたほうが安全だな。


 |  16:00  |  UWSC  |  トラックバック(0)  |  コメント(9)  |  Top↑

2008.05.27 (Tue)

FC2ブログでファイルを一括アップロード - UWSC

追記
現在の最新版はFC2ブログでファイルを一括アップロード【更新】 - UWSCになります。
IE8の場合はこのUWSCスクリプトだとアップロードできません。

IE8でもアップロードするために一括アップロード用のソフトを自作したので、
どこぞの知らない人が作ったソフトにIDやパスワードを入れるのに抵抗がなければ使ってみてください。
FC2ブログでファイルを一括アップロードするソフトを作ったよ




このFC2ブログってファイルを一括でアップロードする機能がついていなくて、
画像をたくさんアップしたい場合にものすごいめんどくさい。
ということで、UWSCで一括アップロードスクリプトを書くことにしました。

動作は単にIEでアップロード画面を開き、指定フォルダ(SRC_DIR)内のすべてのファイルを順次アップロードするという動作。


使い方
1.USERIDにFC2ブログのユーザーID、PASSWORDにパスワードを入れるか、IEでFC2ブログにログインしておく(ログイン状態であればID,パスワードは不要)
2.任意の場所にフォルダを作成し(D:\Temp\updirとか)、アップロードしたいファイルを作成したフォルダに入れる
3.「SRC_DIR」に2.で作成したフォルダのパスを入れる
4.UWSCで以下のスクリプトを実行

注)指定したフォルダ内のすべてのファイルをアップロードしようとするので、アップロードし終わったファイルは削除してください


FC2ブログ一括アップロード.txt
↑拡張子を.UWSに変更して使用してください

↓中身はこんな感じ



// *****************
// 基本設定
// *****************
PUBLIC USERID = "user"
PUBLIC PASSWORD = "pass"
PUBLIC SRC_DIR = "D:\Temp\updir"  //アップロードフォルダ



// *****************
// 設定内容の確認
// *****************
ifb SRC_DIR = "" then
  msgbox("アップロード対象フォルダが設定されていません")
  exit
endif

try
  // ファイルの取得
  filecount = GetDir(SRC_DIR)
  // アップロードするファイルがない場合終了
  ifb filecount = 0 then
    msgbox("アップロード対象ファイルが見つかりません。<#cr>" + SRC_DIR)
    exit
  endif
except
  // 例外が発生したら終了
  msgbox("エラー:" + TRY_ERRMSG)
  exit
endtry


PUBLIC IE = CreateOLEObj("InternetExplorer.Application")
PUBLIC ID = HNDTOID(ie.hwnd)

// *****************
// メイン処理
// *****************
IE.Visible = true;
// FC2ブログhpを開く
IE.Navigate("http://blog.fc2.com/");

REPEAT
 SLEEP(1)
UNTIL !IE.busy AND IE.readystate=4

// ログインフォームが存在する場合
ifb IE.document.getElementsByName("login").length > 0 then
  frm = IE.document.getElementsByName("login").Item(0)
  IE.document.getElementById("acid").value = USERID
  IE.document.getElementById("passwd").value = PASSWORD
  frm.submit()
else
  IELINK(IE, "・ブログ管理画面へ")
endif

REPEAT
 SLEEP(1)
UNTIL !IE.busy AND IE.readystate=4


ifb pos("管理ページ", STATUS(ID, ST_TITLE)) = 0 then
  // ログインできなかったら終了
  msgbox("ログインできませんでした。")
  exit
endif

// アップロード画面を開く
IELINK(IE, "ファイルアップロード")
REPEAT
 SLEEP(1)
UNTIL !IE.busy AND IE.readystate=4


// ファイル数分アップロード
for i = 0 to filecount - 1
  // フォーム取得
  frm = IE.document.getElementsByName("upload").Item(0)
  // ファイルパス
  filepath = SRC_DIR + "\" + GETDIR_FILES[i]
  
  // 最小化してるとファイル名が入らないので戻す
  if STATUS(ID, ST_ICON) then CTRLWIN(ID, NORMAL)
  
  // ファイル入力ボックスにフォーカスを当てる
  frm.upfile.focus()
  // sendstrで入力
  sendstr(ID, filepath)
  
  inputs = frm.getElementsByTagName("input")
  // type=submitを探す
  for j = 0 to inputs.length - 1
    ifb inputs.item(j).type = "submit" then
      // 見つかったらクリックしてアップロード
      inputs.item(j).click
      break
    endif
  next
  
  REPEAT
   SLEEP(1)
  UNTIL !IE.busy AND IE.readystate=4
next

msgbox("完了")




 |  18:16  |  UWSC  |  トラックバック(0)  |  コメント(2)  |  Top↑

2008.04.14 (Mon)

Excelで大量ループの中にMsgBoxを入れてしまった!

ExcelVBAで大量ループの中にMsgBoxを入れてしまった!
未保存なので強制終了はさせたくないが、ループが終了するまでMsgBoxの「OK」ボタンを押し続けるのはかなりキツイ!!

デバッグをMsgBoxでするタイプなのでこういうことがよくある。
ダイアログが常に手前に出てきてくれるのであればEnter押しっぱなしでも行けるのだが、
「OK」ボタンを押すたびに後ろに隠れやがることもある。

そんなときはUWSC


WHILE true
  ID = GetId("Microsoft Excel", "#32770")
  IF ID = -1 THEN BREAK
  CLKITEM(ID, "OK")
  SLEEP(0.1)
WEND


これでひたすらOKボタンをクリックしてくれる。
ありがとうUWSC。本当に役に立つ子だ。


 |  14:19  |  UWSC  |  トラックバック(0)  |  コメント(0)  |  Top↑

2008.03.13 (Thu)

ハンゲームのパチンコDX自動終了 - UWSC

ハンゲームのパチンコDXで
玉がなくなったら自動で終了し、更にPCをシャットダウンするマクロ。

これで安心してコモモ動かしながら寝れる!


PID = GETID("パチンコDX")

REPEAT
  END_FLG = 0
  // 終了時のダイアログ取得
  END_DLG =  GETID("パチンコDX", "#32770", 1)
  wk = getstr(END_DLG, 1, STR_STATIC)
  
  IFB pos("DX専用玉がなくなりました。", wk) > 0
    CLKITEM(END_DLG, "OK")
    END_FLG = 1
  ENDIF
  
  // 60秒間待ち
  SLEEP(60)
UNTIL END_FLG = 1

// パチンコDXを閉じる
CTRLWIN(PID, CLOSE)
// 終了しますか? の確認ダイアログが出る
END_DLG =  GETID("確認", "#32770", -1)
CLKITEM(END_DLG, "はい")

// シャットダウン(シャットダウンしない場合は下の一行削除)
POFF(P_SHUTDOWN OR P_FORCE)


 |  11:50  |  UWSC  |  トラックバック(0)  |  コメント(0)  |  Top↑
 | BLOGTOP |  NEXT
上記広告は1ヶ月以上更新のないブログに表示されています。新しい記事を書くことで広告を消せます。