【问题标题】:Merge Two csv files with php用php合并两个csv文件
【发布时间】:2015-08-05 16:41:42
【问题描述】:

我有两个 csv 文件:一个包含合同数据,另一个包含已授予合同。我需要使用公共字段(合同名称)组合这两个文件并计算当前授予合同的总数。 链接到 csv 文件: https://github.com/younginnovations/problem-statements/tree/master/clean-up-contracts-data

我确实得到了所需的输出 bt 出现未定义的偏移错误。 代码:unset(awards_info[$y][0]);确实取消设置数据,但出现“未定义的偏移量:0”错误.. 同样,代码 $list_data[10]!=NULL 也显示相同的错误 但两者都产生了所需的输出。

var_dump($awards_info):: produces following:
array(5) { [0]=> array(6) { [0]=> string(12) "contractName" [1]=> string(12) "contractDate" [2]=> string(14) "completionDate" [3]=> string(7) "awardee" [4]=> string(15) "awardeeLocation" [5]=> string(6) "Amount" } [1]=> array(6) { [0]=> string(15) "Contract-2070-3" [1]=> string(8) "5/9/2014" [2]=> string(9) "8/25/2014" [3]=> string(11) "SK Builders" [4]=> string(5) "Banke" [5]=> string(6) "200000" } [2]=> array(6) { [0]=> string(15) "Contract-2070-5" [1]=> string(9) "3/18/2014" [2]=> string(8) "4/8/2014" [3]=> string(24) "S engineering industries" [4]=> string(9) "Makwanpur" [5]=> string(6) "300000" } [3]=> array(6) { [0]=> string(15) "Contract-2070-9" [1]=> string(8) "3/6/2014" [2]=> string(8) "4/6/2014" [3]=> string(24) "Gourishankar nirman sewa" [4]=> string(8) "Lalitpur" [5]=> string(6) "400000" } [4]=> array(6) { [0]=> string(16) "Contract-2070-10" [1]=> string(8) "2/6/2014" [2]=> string(9) "6/16/2014" [3]=> string(11) "SK Builders" [4]=> string(5) "Banke" [5]=> string(6) "400000" } }
$file_contract=fopen('contracts.csv','r');
$file_awards=fopen('awards.csv','r');
 while(($data=fgetcsv($file_contract))!=FALSE){
$contracts_info[]=$data;
}

while(($data=fgetcsv($file_awards))!=FALSE){
$awards_info[]=$data;
}

$con_count=count($contracts_info);
for($x=0;$x<$con_count;$x++){

    if($x==0){
        unset($awards_info[0][0]);
        $data[$x]=array_merge($contracts_info[0],$awards_info[0]);
        }

    else{
        $check=0;
        $award_count=count($awards_info);
        for($y=1;$y<$award_count;$y++){

            if($awards_info[$y][0]==$contracts_info[$x][0]){

                unset($awards_info[$y][0]);
                $data[$x]=array_merge($contracts_info[$x],$awards_info[$y]);
                $check=1;
                }

            }

            if($check==0){
                $data[$x]=$contracts_info[$x];
                }
        }
}
$final_data=fopen('final.csv','w');
foreach($data as $list_data){
    fputcsv($final_data,$list_data);
    }
    fclose($final_data);
    $c=0;


foreach ($data as $list_data){
    if(($list_data[1]=='Current') && ($list_data[10]!=NULL))
    {
        $c+=$list_data[12];

        }
    }

echo $c;

【问题讨论】:

  • 该数组不包含任何内容,因此[0] 尝试指向不存在的内容。无论你遇到什么错误,都开始做var_dump($whatever),看看你真正在处理什么。
  • 该数组确实包含一个值...当我回显该数组时,它确实显示其值而没有任何错误。 Bt 当我使用未设置的错误时显示在上面一行。 (即未设置代码之前的行)。

标签: php csv


【解决方案1】:

你可以只在新文件中添加内容文件,而不需要解析文件:

$fp = fopen('final.csv','w');
fwrite($fp, file_get_contents('contracts.csv'));
fwrite($fp, file_get_contents('awards.csv'));
fclose($fp);
echo file_get_contents('final.csv');

好的,这是错误的方法。所以我尝试重写循环:

for($x=0; $x < count($contracts_info); $x++) {
  $data[$x] = $contracts_info[$x];
  if($x == 0) {
    if(isset($awards_info[$x])) {
      $data[$x] = array_merge($data[$x], $awards_info[$x]);
      unset($awards_info[$x]);
    }
  } else {
    foreach($awards_info as $y => $award_info_datas) {
      if($award_info_datas[0] == $contracts_info[$x][0]) {
        $data[$x] = array_merge($data[$x], $award_info_datas);
        unset($awards_info[$y]);
        break;
      }
    }
  }
}

【讨论】:

  • 我不能简单地从两个文件中获取所有数据并将它们堆积起来。如果它们具有相同的合同名称,我需要合并数据。所以这对我来说不是一个好的选择。反正这些都已经完成了,唯一困扰我的是未定义的偏移错误
  • 好的,抱歉。那么你能给我们你的 $awards_info 和 $contracts_info 的 var_dump 吗?
  • 我用 var_dump($awards_info) 输出编辑了我的问题
  • 该代码也没有帮助...但我确实解决了问题.. :) 我之前没有使用 isset 代码...这有帮助。无论如何谢谢你
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2011-01-26
  • 1970-01-01
  • 2012-08-12
  • 2013-04-22
  • 2020-11-22
  • 1970-01-01
  • 2013-02-11
相关资源
最近更新 更多