2011/12/16(金)ICQのログ発掘

2011/12/16 14:24 PC(全般)
かなり今更だが、ICQのログを参照する機会があったのでちょっとメモ。

ICQは各バージョンデータの保持形式が違う上、少なくとも2003bくらいまではログの書き出し機能もなければプラグイン等での対応もできなかった(はず)。ログを参照するだけならICQをインストールし直せば見られるのだが、日付からの検索ができるだけで一括エクスポートなんかができない。

ということで何らかの方法で抽出しないといけない。サーベイするとだいたい候補が2つ。

ICQ バックアップ

Belkasoft ICQ Analyzer

上は無料、対応バージョンが限定(完全に確認してないが99~2001(2002も?)と思われる)。ICQがインストールされている必要がある。使い方が難しい。

下は有料、簡単、対応バージョンはたぶんすべて。チャットログ以外に、承認要求やファイル転送ログもとれそうだ(ただし一部文字化けするっぽい)。ICQのインストール不要。

他に、ABC Amber ICQ Converterというのもあったのだが、Belkasoftに機能面で負けてそうなので割愛。

今回取り出したいのは、99b~2001bとちょうどICQバックアップの対象範囲に合致したので、とりあえず上で試すことにした。

ICQバックアップはICQがインストールされている必要があるので、まずICQをインストールする。ただしバージョンに制約があるので注意。2003とかだとうまく抽出ができない。なんとかICQ2001b辺りを探して来てインストール。

次に、抽出したいログを含む
  • アカウント番号.dat (cf. 11111111.dat)
  • アカウント番号.idx (cf. 11111111.idx)
を含む2001aだとかDb99bとかのフォルダをインストールした場所に全部突っ込む。

これでICQバックアップを立ち上げると、自動認識して対応範囲のバージョンのログは抽出できる…はず。

やってみたところ、だいたい問題なくとれたようなのでこれで良しとする。

なんかめんどくさかったのでおとなしくあきらめるとか、Belkasoftに金払った方がよさそう(ICQ History Extractorという旧製品もあり、こちらはAnalyzerよりだいぶ安い。まだPurchaseできるならこちらか)。

2011/12/09(金)TVTestが終了時に落ちてその後の録画に失敗する

2011/12/09 16:54 PC(全般)
TVTestが原因と思われる録画失敗が多発しているため、前回の残件も含めてちょっと調査してみた。
[状況]
  • TvRock0.9u2 + TVTest0.7.23(Win7 x64) + PT2
  • 特定の入力デバイス(地デジ1なら地デジ1)に割り付けられた予約がある時刻から失敗している。
  • 確認してみると、TVTestが不応答状態で残っている(そのデバイスに割り付けられたもの)。
  • 録画ファイルが生成されていない(0bytesですら残っていない)
調査対象はTVTest0.7.15, 0.7.17, 0.7.18r3, 0.7.20, 0.7.21r2, 0.7.22r2, 0.7.23

まず、先日と同じく、コマンドラインは
>tvtest.exe /rec /recfile "test%test.ts"
で調査する。

[1]録画ファイル化けの問題。
  • 0.7.15-0.7.20は"test%test.ts%"になり化ける。
  • 0.7.21r2-0.7.23は"test%test.ts"になり正常。
[2]TVTest落ちの問題。
ドライバも何もない状態で起動し、数秒後に録画停止ボタンを押して録画停止する。
  • 0.7.15-0.7.17は正常に停止する。
  • 0.7.18r3-0.7.23は異常終了(ハンドルされていないWin32例外)する。
ここで、異常終了するケースで色々試してみると、
  • "/recexit"オプションを付けると異常終了しない。
  • ファイル名に"%"を含まない場合は異常終了しない。
"%"については残件調査のつもりで始めたのだが、ここで原因が確定してしまった。"%"を含むファイル名で録画すると、TvRockからTVTestの終了に失敗する。そうすると、手動でこのプロセスを落とすまで以降このTVTest側に割り付けられた予約がすべて失敗するということのようだ。具体的には前回と同じく、"うたの☆プリンスさまっ♪マジLOVE1000%"が原因で、その後に来た"UN-GO"と"ギルティ クラウン"が失敗したということになる。この話どうでもいいな。

"/recexit"を付けるとなんか改善するのは現行TVTest/RecTestの常っぽい(RecTestでも類似バグがあった)。

運用に関してはとりあえず/recexit付けて様子を見ることにする。改善要望出して、ソース読める時間とれたらもうちょっと解析してみよう。DirectX SDKとDirectShowのBaseClasses入れないといけない……

2011/12/06(火)HSV解析メモ

2011/12/06 9:32 PC(全般)
画像をHSV値で眺めたり分析したりしたいときがある。
その際使用するツールとかのメモ。
  • 各画素値を取るなら
    • 自前で書く。
  • ヒストグラムを見たいなら
    • PaintStar(DPExの方が見やすいけどシェアウェア)
  • チャンネル毎に分解したいなら
    • GIMPで色→色要素→チャンネル分解
  • 色のピックアップ
    • Photoshopでも何でも。
なお、自前で書く際に.NETを使用する場合、GetPixel()が天地を貫くほど遅いので、
Mr.Exception 画像処理にGetPixel/SetPixelを使っていませんか?
などを参考とすること。

OpenCV周りもそろそろ触らないとなあ。

チャンネル分解でHレイヤーに色つけてくれるツール募集中(ImageNosでできそう?)。

2011/11/15(火)PDF内の画像フォーマット

2011/11/15 15:26 PC(全般)
前記事の付随記事。
画像で構成されたPDF内の画像フォーマットを調べたい。

なんとAcrobat X Proでは表示する方法がない(!?)。

現状これができるツールがみつけられなかったが、とりあえず調べ方はわかった。
テキストエディタでPDFの中をのぞく。
<< /Type /XObject /Subtype /Image /Name /Obj4 /Width 1811 /Height 2365 
/BitsPerComponent 8 /ColorSpace /DeviceRGB
/Filter /DCTDecode /Length 634114 >> 
stream
こういったエントリがあるので/Filterのところをチェック。こいつはDCTDecodeなので結局JPEG。うーん、FlateDecode(可逆圧縮)を期待していたのだが……

他のフォーマットは、ここでも参照してほしい。

さて、この場合Acrobat X Proで名前をつけて保存->画像->JPEGとやると、品質設定如何に関わらずオリジナルのJPEG(上記の場合1811x2365 634114bytes)のファイルを抽出できる。

かなりブロック・モスキートノイズが飛んでいる。このJPEG、品質はどれくらいで作られたのか調べたい。量子化テーブルの話なので、逆算は必ずしも正確ではないだろうが大まかの当たりをつけたい。

info_JPEGというソフトで調べられるという話なのでこれを使用。品質は60だった。

このソフトを信じるならこの数字。自分の見た目としての実感も60~70くらいかなという感じなので、大きく外してはいないだろう。

なお、GhostScriptを経由したIrfanView等では、この画像サイズがとれないのか出力指定解像度でしか抽出できなかった。安定してやるならAcrobatでやるのが良い。

2011/11/15(火)ブックメンテナンス秋葉原に行ってきた

2011/11/15 14:52 PC(全般)
ブックメンテナンス秋葉原に2回ほど行ったので、機材のクセや使用方法について思うところをメモしておこうと思う。

今回の目的は自宅にあるA4超サイズ雑誌切り抜き(2000年以前)のデジタル化。現時点(2011/11/15)で、この作業においてライセンス&法律に抵触することはないと理解している。

ブックメンテナンス秋葉原は基本的にレンタル機材サービスをしている店だ。使用料を払って機材を一定回数、もしくは一定時間借りる。機材を使用するのは基本的に客であるが、店員がガイドあるいは手伝いをしてくれるときもある。機材としてはドキュメントスキャナが主体であるが、紙揃えや裁断機等々機材の種類も多くちょっと変わったラインナップになっている。性質としてはKinko'S等に近いものがあり、コピーサービスの特殊拡張と思うとわかりやすい感じだろうか。価格設定はかなり高めだが業務用高級機がそろっており、ここのバランスをどう見るかは人次第であろう。特にA3ドキュメントスキャナはコンシューマー用製品がほとんど無いため、これを使える点はメリットとなる。

今回この店を使用することにしたのは、A4超の切り抜きが大量発掘されてしまったことに端を発する。自宅にあるドキュメントスキャナ(fi-6130)ではA4までしか対応しておらずどうしようかと思案していたのだが、ちょうどこの店の話を聞きつけたので話の種に使ってみることにした。

料金表は店のHPを見て欲しい。ただ、説明不十分なところが多々あるため疑問点は電話で確認しておくといいだろう。

自分が使ったサービスでいうと紙揃え(空流で紙をそろえる)(無料。裁断の100円に含まれると理解)。裁断(手動)(1回100円)。スキャン(低速)(10分500円)。

紙揃えは店員がやってくれ、裁断はセットまでやってもらった。基本的には慣れるまでは手伝ってもらう形になると思う。裁断機はレジ付近にあるので、中身を見られたくない人は裁断は自前でやった方が良いかもしれない。これらの支払いは直接レジに現金で支払う。

低速スキャンブースはPC+コインタイマー+ドキュメントスキャナの組み合わせ。低速ブースでもCanon DR-9080CというA3対応業務機(定価100万円以上)がおいてある。事前にCapturePerfectのマニュアルくらいは読んでおいた方が良いかもしれない。スキャンブースは狭く、しかも足下にスキャナが置いてあるため蹴らないように注意。スキャン物を入れるためのかごを店内で貸してもらえるが、サイドに置くと隣のスペースに侵犯するため混んでるときはどうするのか疑問。荷物があるともうどうしようもない気がする。

PCからUSBの挿入口(メス)が机の上に取り回されているので、そこにUSBメモリやUSB HDDを挿すことができる。スキャンしたデータはそこから持ち帰ることになる。何度か使ってみて考えたのだが、(電源容量が足りれば)USB HDDを持って行くのがベストのようだ。標準では書き出し先がマイドキュメントになっているのだが、PC自体のスペックが余り高くないようでマイドキュメントから移そうとするとかなり時間がかかる。持ち込んだメディアに直接出力するのが良い。フラッシュメモリ系だと転送速度に足を引っ張られるため、その分時間ロスになることに留意しておこう。

スキャン設定は前使用者の設定が残っている可能性もある(日によって初期状態が違った)。そういじるところはないがチェックしておこう。基本はdpi、カラー/グレースケール、片面/両面、保存形式(bmp/jpg/pdf/tif)、出力先フォルダ、マルチページ/シングルページくらいをチェックでよいと思う。

設定について。tifはまず非可逆圧縮の設定ができないため除外(BMP相等とjpg相等しか作れない)していい。大容量メディアを持ち込んだ場合は原版としてBMPで取り込むのもいいだろう。もちろんこの場合、転送速度と空き容量に気を配る必要がある。jpgの場合、圧縮率をきちんと設定すること。この後で加工の予定がある場合、品質95以上にするのが望ましいと思われる。PDFの場合、いきなり出力できるのはメリットだが、自分の場合PDF出力(モード:標準)を選んだ際に、品質60相等のjpgで固められてしまったので注意。何か設定が必要だったのかもしれない。解像度は300dpiか200dpiあたりが一般的か。そこはお好みで。

初回は上記の使い方について店員からガイダンスを受けることになる。作業後にマイドキュメントからファイルを消すように説明されるが、通常の削除を実行してしまった場合ゴミ箱への移動だけで数分費やす羽目になるので注意。完全削除(Shiftキー押しながら削除)をするようにしよう。

スキャンのみ支払い方法が異なり、PC横のコインタイマーに500円硬貨を放り込んで一定時間(低速なら10分)使う形になる。従って、10分は厳密に10分なので注意。何度か使う予定があるなら、まずは低速で慣れた方が良いだろう。5分だと初回のガイダンスだけで終了してしまう恐れがある。時間切れ後3分(と説明を受けた)はリコイン可能時間で、この間はコイン投入を促す画面に強制的に切り替わる。この間バックグラウンドでプロセスは動いているようなので、転送最後数秒とか言う状態ならおそらくだが転送完了まではこぎ着ける。ただ操作はできないため、「安全な取り外し」はできないだろう。リコインすれば復帰し、リコイン猶予時間が終わると初期画面に戻る。初期画面に戻ると、作業中データはすべて消える(と説明を受けた)。

なお、このコインタイマーはどうやら500円しか受けつけない。店内には100円両替機と500円両替機があるが、引っかからないようにしよう。

この記事は2011/11月末くらいまで随時更新するかもしれない。

2011/11/06(日)春M(SpringM)のタイムスタンプ仕様の確認

2011/11/06 11:11 PC(全般)
春M(1.50k41)でタイムスタンプいじってたら、思った通りにソートされなくて???になったのでちょっとメモ。

春Mの「日付の変更」ダイアログで変更できるのは最終変更日時。

さて、FAT32とNTFSでは記録精度が違う。春Mは古いソフトなので、FATの仕様を引きずっている。まあ現在でもFATファイルシステムはUSBメモリなど随所にあり、他のファイルシステムでもNASやバックアップ・ファイルコピーツール等々で同様に発生する問題でもある。

[NTFS]
作成日時:100ナノ秒単位で記録
最終変更日時:100ナノ秒単位で記録
最終アクセス日時:100ナノ秒単位で記録(ただし、1時間以内の同種のアクセスは無視)
参考:NTFSの最終アクセス日時 - B-) の独り言

[FAT32]
作成日時:10ミリ秒単位で記録
最終変更日時:偶数秒単位で記録
最終アクセス日時:1日単位で記録
参考:File Allocation Table

記録時間がUTCかローカルかって違いもあるけど割愛。

で、春Mの場合、「日付の変更」ダイアログでは秒単位まで入力可だが、内部で偶数秒単位に丸めている。また、表示も偶数秒単位に丸められる。ただし、更新の場合と表示した場合でちょっと挙動が違う。

[更新した場合]
2011/11/06 09:54:26に更新→2011/11/06 09:54:26.0000000で記録
2011/11/06 09:54:27に更新→2011/11/06 09:54:26.0000000で記録
2011/11/06 09:54:28に更新→2011/11/06 09:54:28.0000000で記録

切り下げっぽい動きになる。

[表示した場合]
2011/11/06 09:54:26.0000000→2011/11/06 09:54:26
2011/11/06 09:54:26.0000001→2011/11/06 09:54:28
2011/11/06 09:54:26.9999999→2011/11/06 09:54:28
2011/11/06 09:54:27.0000000→2011/11/06 09:54:28
2011/11/06 09:54:27.9999999→2011/11/06 09:54:28

切り上げっぽい動きになる。

さらにややこしいことに、Windowsのファイルプロパティ(秒まで表示)では、
[ファイルのプロパティ(Win7Pro 64bitで確認)]
2011/11/06 09:54:26.0000000→2011/11/06 09:54:26
2011/11/06 09:54:26.0000001→2011/11/06 09:54:26
2011/11/06 09:54:26.9999999→2011/11/06 09:54:26
2011/11/06 09:54:27.0000000→2011/11/06 09:54:27
2011/11/06 09:54:27.9999999→2011/11/06 09:54:27

切り下げっぽい動きになる。

春Mの画面上のソートはナノ秒まで含めて正確に行われるようなので、ちょっと混乱した。

なお、ActiveRuby1.8.7のFile.mtime(秒まで取得可)の挙動とかも確認してみたけど、基本Windowsのプロパティ画面に出てくる値と同じだった。本当はどのAPIを使ってるかも調べるべきなのだが、とりあえず今回はここまで。

調査は
Restamper
とか使った。こっちが信用できないともう知らん。

2011/11/03(木)TVTestで録画ファイル名が文字化け

2011/11/03 17:23 PC(全般)
TVRock(0.9u2)->TVTest(0.7.7)で録画した際に、録画ファイル名が文字化けした問題。

これはTVTestの問題で、条件は録画ファイル名に"%"(半角パーセント)を含むこと。

簡単な再現コマンドはこう。
>tvtest.exe /rec /recfile "test%test.ts"
このとき出来るファイル名は"test%test.ts%"とかになる。パースと置換の問題なので、情報が落ちる場合もあり。率直に言うと、
"うたの☆プリンスさまっ♪マジLOVE1000% #12「迷子のココロ」 2011-09-17(土)_2400 _MXテレビ_201109180000.ts"

"うたの☆プリンスさまっ♪マジLOVE1000% #12「迷子のココロ」 2011-09-17(土)_240%"
になってしまった。

で、結局のところバージョンアップで改善するようだ。現時点で最新のTVTest0.7.23を入れたところ問題が解消した。

更新履歴を見ても判別できなかったので、どこのバージョンで修正されたかは不明。

2011/11/03(木)ChromePlusで延々エラー

2011/11/03 11:38 PC(全般)
ChromePlusで特定サイト(今回はamazon)を開いたときに毎回ActionScriptエラーダイアログが出る問題。
TypeError: Error #1009: null のオブジェクト参照のプロパティまたはメソッドにアクセスすることはできません。
	at com.amazon.d16g.utilities::JS$/call()
	at com.amazon.d16g.utilities::Logger$/_consoleAvailable()
	at com.amazon.d16g.utilities::Logger$cinit()
	at global$init()
	at com.amazon.d16g.core::Erm()
かなりバカバカしい原因なのだが、自戒のためにメモしておく。

単にこのサイトがIE Tabで開く設定になっていた。

ChromePlusの問題だとばかり思い込んでいたため、Pluginの有効/無効を切り替えたり、Flash Playerを入れ替えたりしていたのだが、いっこうに解決せず???だった。そもそも、エラーダイアログのFlash Playerのバージョンが変わらない時点で気がつかなければいけない。

Flash Playerは開発版でない限りエラーを出さない(はず)。

2011/07/14(木)Windows Updateのゴミファイルの削除方法

2011/07/14 14:25 PC(全般)
Windows Updateのゴミディレクトリ(ランダムな16進文字列。たぶんUUIDかなんかだろう)がC,Dドライブの直下などに作られ、Update以降もずっと消えない問題。

頻出問題なので特に説明はいらないだろう。
なぜか消えないし、作られる場所も謎(書き込み可能HDDのドライブレター末尾直下?)。MSは何を考えているのだろうか。

ということで以下を参考。
WindowsXP 「amd64」「i386」フォルダ"アクセスは拒否されました"と表示される - NL - natural life -

フォルダオプションで"簡易ファイルの共有を使用する(推奨)"をオフにする必要がある。これをしないとセキュリティタブが出てこない。

セキュリティタブさえ出てくれば後は所有権をいじるだけである。

自分の場合はこれで削除可能となった。

2011/05/16(月)adiary編集画面のカーソル消失問題(Chrome系ブラウザ)

2011/05/16 10:32 PC(全般)
adiary(これ)の日記編集画面をChrome系ブラウザで開いた場合にtextareaの左端カーソルが消える問題。うーん、バグか仕様か微妙なところだ。ただ一ついえることは2010年代もブラウザ仕様との戦いが続くって事だな。

[参考]
中級プログラマの自宅でPHP ブログ  Ver.2.25:textarea関連の修正

Chrome狙い打ちのハックがないようなので、
$diff satsuki.css.110516 satsuki.css
622c622
<       padding: 0px 4px 0px 0px;
---
>       padding: 0px 4px 0px 2px;
とりあえず暫定でパッチ入れてみました。

直ったけど悲しい。
OK キャンセル 確認 その他