我有一个有效的CSV上传,它获取数据,将其放入数据库,然后打开一个包含数据表的视图,供用户查看。
我想做的是在视图上有一个按钮,然后开始处理数据,并且只处理添加的新数据。如果表有100个旧行,但我在上载时添加了50个新行,我只想处理它们。听起来很简单,但我想不出一种方法来将数据(要处理哪些行)传递回将进行处理的新控制器。数据在一个数组(id数组)中,并且有太多的变量可以放在url的末尾,因为数组可能有多达400个条目。
我认为做这件事的唯一方法似乎很可怕。我可以使用json encode将数组放入数据库表的一个单元格中,并为该表行赋予一个id。然后,我可以将id从视图传递给新的控制器并检索数组。一定有更好的办法吗?
发布于 2014-06-11 21:03:18
移动解析CSV并将数组构建到它自己的函数中的代码。我们假设您正在创建一个_parse_csv()方法,该方法将接受$filename作为参数,然后读取csv、处理数据并返回一个数组。您可以使用var_export并将处理后的数组写入磁盘,然后在_parse_csv方法中加载,而不是重新处理。
private function _parse_csv($filename) {
// do some stuff with the uploaded csv here
// return an array of data from the csv
return $csv_array;
}在csv upload上调用此方法,并将上传的文件名传递给它。
您的CSV按钮可以将$filename传递给控制器/方法,该控制器/方法将CSV解析为数组进行处理。
使用类属性来定义上载文件夹。处理时不要传递上传文件夹,只传递文件名。
警告:此选项讨论的是不安全的。您需要采取额外的预防措施,以确保用户不能通过猜测filename参数来启动csv处理。
https://stackoverflow.com/questions/24162756
复制相似问题