- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
最终我只是想构建一个将 csv 文件导入 mysql 数据库的页面。
我已成功导入 csv。我已经设置了该页面,以便用户从下拉列表中选择数据库中的哪个字段对应于 csv 中的哪个部分。
例如
student_firstname: [First_Name]
student_surname: [Last_Name]
student_address1: [Street_1]
etc.
之后我构建了 2 个数组,第一个数组告诉我 mysql 字段和 csv 标题,第二个数组是 csv 文件中的原始数据:
Array
(
[firstname] => First_Name
[surname] => Last_Name
[address1] => Street_1
[address2] => Street_2
[address3] => City
[address4] => County
[postcode] => Postcode
[telephone] => Mobile_Phone
[notes] => None
)
Array
(
[0] => Array
(
[Username] =>
[Last_Name] => Jacobs
[First_Name] => Adam
[Email] =>
[Password] => password
[Student_Id] =>
[Middle_Name] =>
[Job_Title] =>
[Department] =>
[Company] =>
[Street_1] => 177 The Road
[Street_2] =>
[City] => Exeter
[County] =>
[Postcode] => EX1 1XX
[Country] =>
[Work_Phone] =>
[Home_Phone] =>
[Work_Fax] =>
[Mobile_Phone] => 01111 1112222
[Website] =>
[Role] => Exeter City
)
[1] => Array
(
[Username] =>
[Last_Name] => Miller
[First_Name] => Adam
[Email] =>
[Password] => password
[Student_Id] =>
[Middle_Name] =>
[Job_Title] =>
[Department] =>
[Company] =>
[Street_1] => The White
[Street_2] => 21A Some House
[City] => Creditery
[County] =>
[Postcode] => EX1 1AA
[Country] =>
[Work_Phone] =>
[Home_Phone] =>
[Work_Fax] =>
[Mobile_Phone] => 07111 112222
[Website] =>
[Role] => Exeter City
)
)
我现在要做的就是创建一个字符串,仅将第二个数组中的值插入到第一个数组中定义的 sql 字段中,这样我就可以添加到 mySQL INSERT 语句中。
例如
INSERT INTO students (student_firstname, student_surname, student_address1, student_address2, student_address3, student_address4, student_postcode, student_telephone, student_notes, student_added) VALUES
('Adam','Jacobs','177 The Road','','Exeter','','EX1 1XX','01111 1112222','',''),
('Adam','Millar','The White','21A Some House','Creditory','','EX1 1AA','07111 11222','','')
我当前的代码如下,以说明我确实得到了一些解决方案,但现在变得一团糟
if (isset($_POST['file_upload'])){
$uploaded = 1;
$lines = explode("\n", file_get_contents($_FILES["csvfile"]["tmp_name"]));
$head = str_replace(" ","_",str_getcsv(array_shift($lines)));
$array = array();
foreach ($lines as $line) {
$row = array_pad(str_getcsv($line), count($head), '');
$array[] = array_combine(str_replace(" ","_",$head), $row);
}
//echo '<pre>';
//print_r($array);
//echo '</pre>';
session_start();
$_SESSION['csvimport'] = $array;
}
if (isset($_POST['submitrecords'])){
$fields = array(
'firstname' => $_POST['student_firstname'],
'surname' => $_POST['student_surname'],
'address1' => $_POST['student_address1'],
'address2' => $_POST['student_address2'],
'address3' => $_POST['student_address3'],
'address4' => $_POST['student_address4'],
'postcode' => $_POST['student_postcode'],
'telephone' => $_POST['student_telephone'],
'notes' => $_POST['student_notes']);
$array = $_SESSION['csvimport'];
echo '<pre>';
print_r($fields);
print_r($array);
echo '</pre>';
foreach ($fields as $dbfield){
foreach(array_keys($array[0]) as $value){
if ($dbfield == $value){
foreach($array as $key => $value2){
$snippet .= ",('" . $value2[$dbfield] . "','" . $studentid[0] . "','" . $studentid[1] . "')";
}
}
}
}
$snippet = substr($snippet,1);
$insertSQL = "INSERT INTO students (student_firstname, student_surname, student_address1, student_address2, student_address3, student_address4, student_postcode, student_telephone, student_notes, student_added) VALUES $snippet";
echo $insertSQL;
}
最佳答案
我从原始数组中删除了“注释”,因为它不包含 CSV 文件中的字段,但稍后会再次添加:
$fnames = array (
'firstname' => 'First_Name',
'surname' => 'Last_Name',
'address1' => 'Street_1',
'address2' => 'Street_2',
'address3' => 'City',
'address4' => 'County',
'postcode' => 'Postcode',
'telephone' => 'Mobile_Phone');
命名第二个数组 $csv
后,以下代码会生成数据库查询:
$db = array();
$db_cols = array_keys($fnames);
foreach ($csv as $key => $value){
$insx = array_intersect_key($value, array_flip($fnames));
$db[$key] = array_combine($db_cols, $insx);
$db[$key]['notes'] = '';
$db[$key]['added'] = '';
}
if (count($db) > 0){
$query = "INSERT INTO students (student_";
$query .= implode(', student_', array_keys($db[0])).") VALUES \n";
foreach ($db as $key => $value){
$query .= "('".implode("','", $value)."'),\n";
}
$query = rtrim($query, ",\n");
echo $query;
}
输出:
INSERT INTO students (student_firstname, student_surname, student_address1, student_address2, student_address3, student_address4, student_postcode, student_telephone, student_notes, student_added) VALUES
('Jacobs','Adam','177 The Road','','Exeter','','EX1 1XX','01111 1112222','',''),
('Miller','Adam','The White','21A Some House','Creditery','','EX1 1AA','07111 112222','','')
关于PHP - 基于另一个数组显示一个数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18131644/
我的Angular-Component位于一个flexbox(id =“log”)中。可以显示或隐藏flexbox。 我的组件内部有一个可滚动区域,用于显示日志消息。 (id =“message-li
我真的很困惑 有一个 phpinfo() 输出: MySQL 支持 启用 客户端 API 版本 5.5.40 MYSQL_MODULE_TYPE 外部 phpMyAdmin 显示: 服务器类型:Mar
我正在研究这个 fiddle : http://jsfiddle.net/cED6c/7/我想让按钮文本在单击时发生变化,我尝试使用以下代码: 但是,它不起作用。我应该如何实现这个?任何帮助都会很棒
我应该在“dogs_cats”中保存表“dogs”和“cats”各自的ID,当看到数据时显示狗和猫的名字。 我有这三个表: CREATE TABLE IF NOT EXISTS cats ( id
我有一个字符串返回到我的 View 之一,如下所示: $text = 'Lorem ipsum dolor ' 我正在尝试用 Blade 显示它: {{$text}} 但是,输出是原始字符串而不是渲染
我无法让我的链接(由图像表示,位于页面左侧)真正有效地显示一个 div(包含一个句子,位于中间)/单击链接时隐藏。 这是我的代码: Practice
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 4 年前。 Improve this ques
最初我使用 Listview 来显示 oracle 结果,但是最近我不得不切换到 datagridview 来处理比 Listview 允许的更多的结果。然而,自从切换到数据网格后,我得到的结果越来越
我一直在尝试插入一个 Unicode 字符 ∇ 或 ▽,所以它显示在 Apache FOP 生成的 PDF 中。 这是我到目前为止所做的: 根据这个基本帮助 Apache XSL-FO Input,您
我正在使用 node v0.12.7 编写一个 nodeJS 应用程序。 我正在使用 pm2 v0.14.7 运行我的 nodejs 应用程序。 我的应用程序似乎有内存泄漏,因为它从我启动时的大约 1
好的,所以我有一些 jQuery 代码,如果从下拉菜单中选择了带有前缀 Blue 的项目,它会显示一个输入框。 代码: $(function() { $('#text1').hide();
当我试图检查 Chrome 中的 html 元素时,它显示的是 LESS 文件,而 Firefox 显示的是 CSS 文件。 (我正在使用 Bootstrap 框架) 如何在 Chrome 中查看 c
我是 Microsoft Bot Framework 的新手,我正在通过 youtube 视频 https://youtu.be/ynG6Muox81o 学习它并在 Ubuntu 上使用 python
我正在尝试转换从 mssql 生成的文件到 utf-8。当我打开他的输出 mssql在 Windows Server 2003 中使用 notepad++ 将文件识别为 UCS-2LE我使用 file
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我正在尝试执行单击以打开/关闭一个 div 的功能。 这是基本的,但是,点击只显示 div,当我点击“关闭”时,没有任何反应。 $(".inscricao-email").click(function
假设我有 2 张卡片,屏幕上一次显示一张。我有一个按钮可以用其他卡片替换当前卡片。现在假设卡 1 上有一些数据,卡 2 上有一些数据,我不想破坏它们每个上的数据,或者我不想再次重建它们中的任何一个。
我正在使用 Eloquent Javascript 学习 Javascript。 我在 Firefox 控制台上编写了以下代码,但它返回:“ReferenceError:show() 未定义”为什么?
我正在使用 Symfony2 开发一个 web 项目,我使用 Sonata Admin 作为管理面板,一切正常,但我想要做的是,在 Sonata Admin 的仪表板菜单上,我需要显示隐藏一些菜单取决
我试图显示一个div,具体取决于从下拉列表中选择的内容。例如,如果用户从列表中选择“现金”显示现金div或用户从列表中选择“检查”显示现金div 我整理了样本,但样本不完整,需要接线 http://j
我是一名优秀的程序员,十分优秀!