スギ薬局を覗いてきた

最近、あちこちにスギ薬局が続々と開店しているので、どんなお店かなあと思い覗いてきました。
食料品も扱っているドラッグストアなのですが、全体的に特に安いというほどでは無いし、特別に安い目玉品がある訳でもなく、変わったものが売られている訳でもなし、品揃えに優れている訳でもない個人的には全く魅力を感じないお店でした。

同じドラックストアなら、コスモス薬品やゲンキーのほうが魅力があります。

ちなみにネットで検索したら、スギ薬局は親切だという投稿が目につきました。スギ薬局は値段で勝負というお店では無いようです。

ちなみにコスモス薬品は、カートに乗せた買い物かごをレジカウンターに乗せてくれるし、レジを終えた買い物を買い物かごごと買い物袋に入れるカウンターに運んでくれます。
でも心苦しいので、なるべく運ばれる前に自分で運ぶようにはしています。

自動車のバッテリー用の充電装置を購入した

2020年7月7日

自動車のバッテリーを充電しないといけなくなったので、メルカリで850円で購入しました。
12Vのバッテリーを家庭用コンセントで充電する装置です。バッテリ-の種類は密閉式でも開放式でも対応しているとの事です。
充電が完了すればパイロットランプの色が変わるので操作が簡単です。
クリップが小さく、途中で外れそうでちょっと不安な感じです。

さっそく使ってみましたが、出力が1Aなので充電するのに、かなり時間がかかります。
11.4Vまで出力が低下したバッテリーを充電するのに36時間かかりましたが無事充電できました。クリップは外れることは無かったです。
充電が必要なバッテリーは2個あったので、もう一個も使ってみようと思います。

2020年7月9日

長期間運転していない自動車のバッテリーが上がっていたので充電することにしました。
電圧を測ったら2Vしかありませんでした。
これだけ落ちていたら充電完了まで5日くらいかかるのかもしれません。
最初、充電完了の色のランプが点灯したので、充電不良かなと思ったのですが、しばらくして充電中の色のランプが点灯したのでほっとしました。

2020年7月11日

48時間後に確認したら充電完了になっていました。少なくとも36時間以上はかかっていたようです。

緊急時には役立ちませんが、充電することは間違いなくできるようです。

PHPで思うようにsleep()が動作しない

2020年6月12日

30日分の安い宿一覧を、楽天APIのデータを使って表示するPHPプログラムを製作していたのですが、一部の処理を手動にしていたのを全自動で更新できるようにしました。

その際、処理内容を画面で確認するために、途中で処理結果の表示を持続したかったのですが、処理を指定した時間だけ止めるsleep()が効かないんです。

随分頑張って、試行錯誤したのですが解決できず、最後に頼るのはYAHOO!知恵袋です。

原因は、時間がかかる処理をした場合、ブラウザの仕様でバッファをフラッシュするためのようです。
echoコマンドを実行した後に
@ob_flush();
@flush();
を挿入して、その後に
sleep(40);
を挿入すると画面表示した後に、表示を一定時間(今回の場合は40秒)停めて、その後に新しい処理に移る事ができるようになりました。

これで、30日分の最安値宿一覧を、更新内容を確認しながら全自動で更新できるようになりました。やったね。

2020年6月14日

40秒停めても、画面を見続けないといけない事が面倒なので、表示以後の別ウインドウでさせたほうが便利だと気づきました。
PHPで新しいウインドウを開くのが難しく、Javaスクリプトを使わなければいけない事がわかり、実際に試したのですが、うまく動作しませんでした。
結局、アップロードする前に<form   target=”_blank”>で希望通りの処理ができることが分かりました。これだと表示を一定時間(今回の場合は40秒)停止も不要になります。

<body onload=”document.all.jikkou.click();”>
<form action=”https://kimassi.net/insert25.php” method=”post” target=”_blank”>
<input type=”hidden” name=”up_file” value=”<?= urlencode(file_get_contents(‘../../../data/output/csv-put2.csv’)) ?>”>
<input type=”submit” value=”up” name=”jikkou”>
</form>
</body>

灯油の給油をしておいた

新型コロナの影響で石油関連の価格が下がっていますが、徐々に値上げに転じてきたので、灯油を給油することにしました。自動車を運転していると50円以下の看板も見かけます。
それで、ホームセンタームサシに行ったら1リットル55円と思ったより安くなかったので、カナショク松任店に行くと48円(プリペイドカード価格)でした。ちなみにコストコは46円でした。他のお店は70円程度で売られているところもあります。
それでカナショク松任店で購入しました。18リットルノタンク3缶給油しました。灯油にもスロット値引きが1円あったので実質47円でした。
清算後に、次回給油時に使える1リットル当たり5円引きのクーポンも発行されました。
場合によっては42円で給油できることになります。

csv-put.csvファイルをデータベース(MySQ)に

2020年5月30日

現在30日分の安い宿一覧表示について、

1.ローカルのxampp上で楽天APIのデータをcsvファイルとしてハードディスクに保存2.coreserver上のMySQLにアクセスし、テーブルyasuiyadoを選択し先ほどエクスポートしたcsvファイルをインポートする。
フォーマット特有のオプションUpdate data when duplicate keys found on import (add ON DUPLICATE KEY UPDATE)にチェックを入れてインポート)

という作業について、1の部分はPHPで自動でやっているのですが、2の部分は手動でやっているのです。
2の部分もPHPで自動で動作できれば、凄く楽になります。
なんとかならないか調べてみました。

xampp上のPHPからxampp上にあるcsvファイルをcoreserver上にアップロードする事は、なんとかできました。
あとはアップロードしたcsv-put.csvの内容を、サーバーのデータベース(MySQ)に登録することに成功すれば、データベースの自動更新が完成します。

2020年6月7日

結構、苦戦しています。
PHPはバージョンによって仕様が変わるので、過去の情報が役に立たない場合が多いのです。
参考書も、現在のPHPのバージョンにものでないと正常に動作しないし、ネットの情報も、ほとんど役立ちません。

coreserverのデータベースに接続するのは、データベース名がkimassi_yado、ユーザー名がkimassi_yadoなので

<?php
try {
$dsn=’mysql:host=127.0.0.1;dbname=kimassi_yado’;
$db = new PDO($dsn, ‘kimassi_yado’, ‘パスワード’);
} catch (PDOException $e) {
echo ‘DB接続エラー: ‘ . $e->getMessage();
}
?>

csv-put2.csvを開いてデータを配列に変換するのは

<?php
$row = 1;
// ファイルが存在しているかチェックする
if (($handle = fopen(“csv-put2.csv”, “r”)) !== FALSE) {
// 1行ずつfgetcsv()関数を使って読み込む
while (($data = fgetcsv($handle))) {
$row++;

//ここに処理の内容を記入
}
}
fclose($handle);
?>

でできます。テーブルのカラムはid,no,date,check,hotelNo,yadomeiで、配列は

idの内容が$data[0]
noの内容が$data[1]
dateの内容が$data[2]
checkの内容が$data[3]
hotelNoの内容が$data[4]
yadomeiの内容が$data[5]
ryoukinの内容が$data[6]

であることは確認できています。それをデータベースに登録保存するところがうまくいきません。
テーブル名がyasuiyadoなので

$sql =’INSERT INTO yasuiyado (no,date,check,hotelNo,yadomei,ryoukin) VALUES (“$data[1]”,”$data[2]”,”$data[3]”,”$data[4]”,”$data[5]”,”$data[6]”) ‘;
$stmt = $pdo->prepare($sql);
$stmt->execute();

上記で正常に動作するはずなんですが、一行も保存されません。

$sql =”UPDATE yasuiyado SET no=$date[1],date=$date[2],check=$date[3],hotelNo=$date[4],yadomei=$date[5],ryoukin=$date[6]) WHERE id=$date[0]”;

でも一行も保存されません。

2020年6月8日

正常に動作しない原因は、coreserverのデータベースにデータを保存する場合の$sql の構文の問題のようです。

$sql =”INSERT INTO `yasuiyado` (`id`, `no`, `date`, `check`, `hotelNo`, `yadomei`, `ryoukin`) VALUES (‘$data[0]’, ‘$data[1]’, ‘$data[2]’, ‘$data[3]’, ‘$data[4]’, ‘$data[5]’, ‘$data[6]’)”;
$stmt = $db->prepare($sql);
$stmt->execute();

で動作するようになりました。” と ` と ‘ の使い分けが重要のようです。
ちなみにsqlの書式はサーバーによって違うようです。
$sqlは、実際に手動でデータを1件登録してみて、その時のsqlを表示させて調べることができました。

<?php
try {
$dsn=’mysql:host=127.0.0.1;dbname=kimassi_yado’;
$db = new PDO($dsn, ‘kimassi_yado’, ‘パスワード’);
} catch (PDOException $e) {
echo ‘DB接続エラー: ‘ . $e->getMessage();
}
?>
<?php
$row = 1;
// ファイルが存在しているかチェックする
if (($handle = fopen(“csv-put2.csv”, “r”)) !== FALSE) {
// 1行ずつfgetcsv()関数を使って読み込む
while (($data = fgetcsv($handle))) {
$row++;

$sql =”INSERT INTO `yasuiyado` (`id`, `no`, `date`, `check`, `hotelNo`, `yadomei`, `ryoukin`) VALUES (‘$data[0]’, ‘$data[1]’, ‘$data[2]’, ‘$data[3]’, ‘$data[4]’, ‘$data[5]’, ‘$data[6]’)”;
$stmt = $db->prepare($sql);
$stmt->execute();
}
}fclose($handle);
?>

全部まとめて動作させたら、思った通りにいかなくて一瞬焦りましたが、PHPファイルをUnicode(UTF-8)で保存するのを忘れていました。思わぬところで落とし穴があるものです。
ファイルに日本語が入っていないと、エディターで読み込むときにシフトJISで読み込みます。その状態で編集して保存すると、シフトJISで保存されてエラーになってしまうのです。
どこかに日本語を入れておいてUnicode(UTF-8)で保存すれば次回からは自動でUnicode(UTF-8)になるので便利です。

そういう訳で無事、自動化が出来ました。
パソコンは、この処理専用のマシンにしたので、パソコンの電源を入れるだけで自動にデータベースのデータを更新できるようになりました。

2020年6月14日

更新が正常に行われていない事に気づきました。
やっぱり更新はINSERT INTOでは駄目なようです。最初からINSERT INTOで動作するのが不思議だったのです。
UPDATEが正しいのだと思います。3つだけ更新する場合のUPDATEのsqlは

UPDATE `yasuiyado` SET `hotelNo` = ‘1607242’, `yadomei` = ‘Blue Hour Kanazawa2’, `ryoukin` = ‘2400’ WHERE `yasuiyado`.`id` = 1

でした。ちなみにsqlの書式はサーバーによって違うようです。

$sql =”UPDATE `yasuiyado` SET `date` = ‘$data[2]’,`check` = ‘$data[3]’, `hotelNo` = ‘$data[4]’,`yadomei` = ‘$data[5]’, `ryoukin` = ‘$data[6]’ WHERE `yasuiyado`.`id` = $data[0]” ;

で正常に動作しました。