我有一个有效的CSV上传功能,可以将数据弹出到数据库中,然后打开一个包含数据表的视图供用户查看。
我想要做的是在视图上有一个按钮,然后开始处理数据,并且只处理添加的新数据。如果表有100个旧行但我在上传时添加了50个新行,我只想处理它们。听起来很简单,但我想不出一种方法将数据(要处理的行)传递回将要进行处理的新控制器。数据是一个数组(id的数组),因为数组最多可能有400个条目,所以在url的末尾放置太多的变量
我认为这样做的唯一方法似乎很糟糕。我可以使用json编码将数组放入数据库表的单个单元格中,并为此表行提供一个id。然后我可以将视图中的id传递给新控制器并检索数组。必须有更好的方法吗?
答案 0 :(得分:1)
移动解析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上调用此方法并将上传的文件名传递给它。
您的process data
按钮可以将$filename
传递给将CSV解析为数组以进行处理的控制器/方法。
使用class属性定义上传文件夹。处理时不要传递上传文件夹,只传递文件名。
警告:此选项如上所述不安全。您需要采取额外的预防措施,以确保用户无法通过猜测文件名参数来启动csv处理。