.txt ファイルのディレクトリからすべてのコンテンツを取得し、他の情報と一緒にデータベースにアップロードするスクリプトを友人が作成しました。
別名: ファイル名 | コンテンツ
各ファイルの内容 (単純なテキスト情報) は、対応するデータベース エントリに保存されます。これまでのところ非常にうまく機能していますが、新しい一連のテキスト ファイルの内容がまったく読み取られていません。 ファイル名は問題なく読み取られ、その情報はデータベースに簡単にインポートされます。あくまでも実際の内容です。以前にインポートした古い .txt ファイルは、まだ完全にインポートされています。
ファイルの例は次のとおりです: Working / Not-Working
簡単に言えば、一部の .txt ファイルの内容を読み取ることができ、他のファイルを読み取れない理由を知っている人はいますか? おそらくエンコードの問題など?(同一人物で見た目は同じですが) 頭がおかしくなりそうです。
ありがとう!
$dir = 'text';
//createxml(10);exit;
$time_start = microtime(true);
$files = scandir($dir);
natsort($files);
foreach ($files as $v) {
if ($v != "." && $v != ".." && $v != "thumbs" && $v != ".DS_Store") {
//get work done
$text = file_get_contents($dir.'/'.$v);
//get volume, page, county
$ta = explode('.',$v);
$ma = explode('_',$ta[0]);
$last = count($ma)-1;
$volume = '';
$year = '1999';
for ($i = 0; $i < $last; ++$i)
{
$volume .= $ma[$i].'_';
}
$volume = $mysqli->real_escape_string(rtrim($volume,'_'));
$pagenr = $mysqli->real_escape_string($ma[$last]);
$ntext = $mysqli->real_escape_string(getmtext($text));
$pdf = 'http://griffiths.****.ie/gv4/thoms/'.$volume.'/'.$volume.'_pg'.str_pad($pagenr, 4, "0", STR_PAD_LEFT).'.pdf';
$thumb = 'http://griffiths.****.ie/gv4/thoms/'.$volume.'/thumbs2/'.$volume.'_'.str_pad($pagenr, 4, "0", STR_PAD_LEFT).'.jpg';
//create sql
$echo[$volume] .= "('','$year','$pagenr','$volume','$ntext','$pdf','$thumb'),";
$excl[$volume]=true;
}
}
// check if there is volume already in DB
foreach ($excl as $k => $v) {
$volumes .= "'$k',";
}
$volumes = rtrim($volumes,',');
$excls ='';
if ($result = $mysqli->query("SELECT DISTINCT volume FROM thoms_copy2 WHERE volume in ($volumes)")) {
//found volumes already in DB
while ($r = $result->fetch_array(MYSQLI_NUM))
//we only need the new volumes, so we will ignore the rest
unset($echo[$r[0]]);
$result->close();
}
//create mysql string
foreach ($echo as $k => $v) {
$echot .= $v.',';
}
$echot = rtrim($echot,',');
if ($echot) {// if i have something to insert
//insert into DB
$sql = "INSERT INTO `thoms_copy2` (`id`,`year`,`main_page`, `volume`, `texty`, `pdf`, `thumb`) VALUES $echot";
if ($result = $mysqli->query($sql)) {
echo "Done.";
//create the XML file
createxml($mysqli->affected_rows);
} else {
printf("Error message: %s\n", $mysqli->error);
echo "<br><br>$sql";
}
} else { echo "Done. Nothing new."; }
$time_end = microtime(true);
$time = $time_end - $time_start;
echo "<br>$time";
//functions ===============================================================
function getmtext($str) {
$text = '';
$words = str_word_count($str, 1);
foreach ($words as $word) {
if ($word[0] >= 'A' && $word[0] <= 'Z')
if (strlen($word)>1)
$text .= $word.' ';
}
return $text;
}