[英]Remove line(s) from a CSV file and generate a new file automatically
我正在嘗試使用PHP操作現有的.csv文件! 我查看了大多數StackOverflow問題,並找到了“ Myke Black”用戶的答案,該答案最適合我的需求。
我設置$id=2
,因此我希望代碼會影響我的.csv文件中的第2行,並且將生成一個新的生成的不包含第2行的.csv文件。
這是我的代碼:
$id=2;
$fptemp = fopen('files/FL_insurance_small-temp.csv', "a+");
if (($handle = fopen('files/FL_insurance_small.csv', "r")) !== FALSE) {
while (($id= fgetcsv($handle)) !== FALSE) {
if ($id != $data[0]) {
$list = array($data);
fputcsv($fptemp, $list);
}
}
fclose($handle);
fclose($fptemp);
rename('files/FL_insurance_small-temp.csv','files/output/FL_insurance_small_new.csv');
echo "Row with ID: ".$id." successfully deleted!";
} else {
print "There seems to be a problem.";
}
一切似乎正常,因為在輸出文件夾中生成了一個新文件。 我的問題是,新生成的文件為空。 有誰知道為什么? 我想念什么?
示例數據(.csv):
policyID,statecode,county,eq_site_limit,hu_site_limit,fl_site_limit,fr_site_limit,tiv_2011,tiv_2012,eq_site_deductible,hu_site_deductible,fl_site_deductible,fr_site_deductible,point_latitude,point_longitude,line,construction,point_granularity
119736,FL,"CLAY COUNTY",498960,498960,498960,498960,498960,792148.9,0,9979.2,0,0,30.102261,-81.711777,Residential,Masonry,1
448094,FL,"CLAY COUNTY",1322376.3,1322376.3,1322376.3,1322376.3,1322376.3,1438163.57,0,0,0,0,30.063936,-81.707664,Residential,Masonry,3
206893,FL,"CLAY COUNTY",190724.4,190724.4,190724.4,190724.4,190724.4,192476.78,0,0,0,0,30.089579,-81.700455,Residential,Wood,1
333743,FL,"CLAY COUNTY",0,79520.76,0,0,79520.76,86854.48,0,0,0,0,30.063236,-81.707703,Residential,Wood,3
172534,FL,"CLAY COUNTY",0,254281.5,0,254281.5,254281.5,246144.49,0,0,0,0,30.060614,-81.702675,Residential,Wood,1
785275,FL,"CLAY COUNTY",0,515035.62,0,0,515035.62,884419.17,0,0,0,0,30.063236,-81.707703,Residential,Masonry,3
995932,FL,"CLAY COUNTY",0,19260000,0,0,19260000,20610000,0,0,0,0,30.102226,-81.713882,Commercial,"Reinforced Concrete",1
223488,FL,"CLAY COUNTY",328500,328500,328500,328500,328500,348374.25,0,16425,0,0,30.102217,-81.707146,Residential,Wood,1
433512,FL,"CLAY COUNTY",315000,315000,315000,315000,315000,265821.57,0,15750,0,0,30.118774,-81.704613,Residential,Wood,1
142071,FL,"CLAY COUNTY",705600,705600,705600,705600,705600,1010842.56,14112,35280,0,0,30.100628,-81.703751,Residential,Masonry,1
253816,FL,"CLAY COUNTY",831498.3,831498.3,831498.3,831498.3,831498.3,1117791.48,0,0,0,0,30.10216,-81.719444,Residential,Masonry,1
894922,FL,"CLAY COUNTY",0,24059.09,0,0,24059.09,33952.19,0,0,0,0,30.095957,-81.695099,Residential,Wood,1
422834,FL,"CLAY COUNTY",0,48115.94,0,0,48115.94,66755.39,0,0,0,0,30.100073,-81.739822,Residential,Wood,1
582721,FL,"CLAY COUNTY",0,28869.12,0,0,28869.12,42826.99,0,0,0,0,30.09248,-81.725167,Residential,Wood,1
讀取文件時-您覆蓋的$id
是您要查找的行。 相反,您的循環應將值分配給$data
。
$rowcount = 1;
while ($data= fgetcsv($handle)) {
if ($id != $rowcount++) {
fputcsv($fptemp, $data);
}
}
$rowCount
是當前正在讀取的行,因此在讀取新行時將其與每一行進行比較。
這還將刪除對$list
的多余分配。
要“刪除”(或省略)記錄列表...
$id= [2,5,7];
$rowcount = 1;
while ($data= fgetcsv($handle)) {
if (!in_array($rowcount++, $id)) { // Only write row if not in the list
fputcsv($fptemp, $data);
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.