Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/61.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
导入CSV时php上出现未定义的偏移量错误_Php_Mysql_Csv - Fatal编程技术网

导入CSV时php上出现未定义的偏移量错误

导入CSV时php上出现未定义的偏移量错误,php,mysql,csv,Php,Mysql,Csv,我正在尝试将一个CSV文件导入到我的数据库中,并在最后成功执行该文件。但是,在执行过程中,我收到一条未定义的偏移量错误消息,当我检查导入的数据时,我看到表中更新了一些空记录。如何避免将这些空单元格导入数据库?我也不希望看到这些错误消息 <?php require_once("database.php"); // Create connection $conn = new mysqli($servername, $username, $password, $dbname); /

我正在尝试将一个CSV文件导入到我的数据库中,并在最后成功执行该文件。但是,在执行过程中,我收到一条未定义的偏移量错误消息,当我检查导入的数据时,我看到表中更新了一些空记录。如何避免将这些空单元格导入数据库?我也不希望看到这些错误消息

    <?php
require_once("database.php");

// Create connection
$conn = new mysqli($servername, $username, $password, $dbname);


// Check connection
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
}

/// Delete table contents
$dsql = "TRUNCATE TABLE User_Mirror_Tbl";

if ($conn->query($dsql) === TRUE) {
  echo "Table content is truncated successfully". PHP_EOL;
  } else {
  echo "Error: " . $dsql . "<br>" . $conn->error;
  }


//read file
$csvfile=file_get_contents("/samba/import/User_Update_Tbl.csv");


//counters:
$record_number=0;
$record_number_err=0;

$lines = explode(PHP_EOL, $csvfile);
$array = array();
foreach ($lines as $line) {
    $field = str_getcsv($line);
      if $field[0] != ''){
$field[1]= ( $field[1] == '' ? NULL : $field[1]);
$field[6]= ( $field[6] == '' ? NULL : $field[6]);
$field[7]= ( $field[7] == '' ? NULL : $field[7]);
        $sql="INSERT INTO User_Mirror_Tbl (History_Record_ID, Employee_ID, Application_ID, User_Status, Record_Date, User_Name, User_Role, Last_Signon, UserKeyString)
                VALUES
                ('$field[0]','$field[1]','$field[2]','$field[3]','$field[4]','$field[5]','$field[6]','$field[7]','$field[8]') ";

        //insert record to database
        if ($conn->query($sql) === TRUE) {
        //      echo "New record created successfully". PHP_EOL;
                $record_number=$record_number+1;
        } else {
                echo "Error: " . $sql . "<br>" . $conn->error;
                $record_number_err=$record_number_err+1;

        }

}
}

echo $record_number.' Successful record and '.$record_number_err.' Unsuccessful record executed.';

$conn->close();



<?php
require_once("database.php");

// Create connection
$conn = new mysqli($servername, $username, $password, $dbname);


// Check connection
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
}

/// Delete table contents
$dsql = "TRUNCATE TABLE User_Mirror_Tbl";

if ($conn->query($dsql) === TRUE) {
  echo "Table content is truncated successfully". PHP_EOL;
  } else {
  echo "Error: " . $dsql . "<br>" . $conn->error;
  }


//read file
$csvfile=file_get_contents("/samba/import/User_Update_Tbl.csv");


//counters:
$record_number=0;
$record_number_err=0;

$lines = explode(PHP_EOL, $csvfile);
$array = array();
foreach ($lines as $line) {
    $field = str_getcsv($line);
      if $field[0] != ''){
$field[1]= ( $field[1] == '' ? NULL : $field[1]);
$field[6]= ( $field[6] == '' ? NULL : $field[6]);
$field[7]= ( $field[7] == '' ? NULL : $field[7]);
        $sql="INSERT INTO User_Mirror_Tbl (History_Record_ID, Employee_ID, Application_ID, User_Status, Record_Date, User_Name, User_Role, Last_Signon, UserKeyString)
                VALUES
                ('$field[0]','$field[1]','$field[2]','$field[3]','$field[4]','$field[5]','$field[6]','$field[7]','$field[8]') ";

        //insert record to database
        if ($conn->query($sql) === TRUE) {
        //      echo "New record created successfully". PHP_EOL;
                $record_number=$record_number+1;
        } else {
                echo "Error: " . $sql . "<br>" . $conn->error;
                $record_number_err=$record_number_err+1;

        }

}
}

echo $record_number.' Successful record and '.$record_number_err.' Unsuccessful record executed.';

$conn->close();

有时您需要忽略csv的最后一行或几行。我将从顶部忽略的行数设置为$start\u offset,将从底部忽略的行数设置为$end\u offset。从零开始增加,直到偏移误差消失。我是这样做的:

$data = file_get_contents($filename);//load up csv

$data_array = explode("\n", $data);//break file into lines
$csv = array_map('str_getcsv', $data_array);//break up comma delimited
$csv_len = count($csv); //count of number of lines
$start_offset = 2;
$end_offset = 3;
for ($i=$start_offset; $i<$csv_len-$end_offset; $i++)
{
    //access columns as $csv[$i][0], $csv[$i][1] etc
}

你问之前试过什么吗?这些将帮助你:和。另外,您应该认真阅读有关SQL注入的内容。我对这一切有点陌生。这就是为什么我问我如何使用这个问题。感谢您对SQL注入的建议。感谢您的评论。当我将此部分插入代码时,在运行代码后会收到下面的错误消息。PHP注意:第30行的/var/www/html/iacd/mirrortableupdate.PHP中使用了未定义的常量start_offset-假定为“start_offset”,对不起,start_offset之前缺少$。我编辑了我的代码并修复了它。你能发送一个示例csv文件吗?我认为在这个网站上添加一个文件是不可能的。