[英]How to separate and modify the content of a string in php?
我讀了一個像這樣的 csv 文件:
391;WETSUITS;07/07/2020 12:47:36;0021000001463;
392;WETSUITS;07/07/2020 12:47:49;0021000007845;
....
我用這種格式檢索一個日期:
echo $data[2] = 07/07/2020 12:47:36
我想有兩個變量:
$date = 07-07-2020 or 2020-07-07
$time = 1247
我在第一部分嘗試使用 str_replace,但收到“通知:未定義偏移量:2”作為錯誤消息,我該如何更改?
<?php
$csv = 'C:/wamp64/www/BI/BI1_20200707_1520_28044.csv';
if (($handle = fopen("$csv", "r")) !== FALSE) {
while (($data = fgetcsv($handle, 9000000, ";")) !== FALSE){
// echo $data[2]; //07/07/2020 12:47:36
$new = str_replace('/', '_', $data[2]);
echo $date = substr($new,0,20)."\n";;
}
}
?>
這個通知可能是因為文件末尾有一個空行。 因此,只需檢查$data
數組是否為空。
while (($data = fgetcsv($handle, 9000000, ";")) !== false) {
// empty line will be transformed to [null]
if (empty(array_filter($data))) {
continue;
}
// other operations
}
建議:更好的是使用 DateTime 進行日期操作。 日期格式參考: https://www.php.net/manual/en/function.date
$date = \DateTime::createFromFormat('d/m/Y H:i:s', $data[2]);
if ($date === false) {
// handle date parse error
}
$date1 = $date->format('Y-m-d'); // 2020-07-07
$date2 = $date->format('Hi'); // 1247
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.