导出/导入具有不同日期格式的表

时间:2019-01-17 23:38:20

标签: php sql csv import export

我遇到了这个问题,当我将表格导出为csv文件并在excel上打开时:日期似乎具有不同的格式(在数据库中:yyyy-mm-dd,而在excel dd / mm / yyyy)

有没有一种方法可以解决这些东西在导出或导入时具有相同的格式

这是我导入时的代码

  elseif ($_POST["program"]=="dengue"){
        $filename = $_FILES['file']['tmp_name']; 
        $file = fopen($filename, "r");
        while (($getData = fgetcsv($file, 10000, ",")) !== FALSE)
         {



           $sql = "INSERT into lcho_dengue_activities (district_id,barangay_id,month,year,dengue_ind1,dengue_ind2,dengue_ind3,dengue_ind4,dengue_ind5,dengue_ind6,dengue_ind7,dengue_ind8,dengue_ind9,dengue_ind10,dengue_ind11,date) 
               values ('".$getData[0]."','".$getData[1]."','".$getData[2]."','".$getData[3]."','".$getData[4]."','".$getData[5]."','".$getData[6]."','".$getData[7]."','".$getData[8]."','".$getData[9]."','".$getData[10]."','".$getData[11]."','".$getData[12]."','".$getData[13]."','".$getData[14]."','".$getData[14]."')";


            if(!mysqli_query($con, $sql))
            {
            echo ("Error description: " . mysqli_error($con));  
            }
            else {
                  echo "<script type=\"text/javascript\">
                    alert(\"CSV File has been successfully Imported.\");
                    window.location = \"imports.php\"
                </script>";
            }
        }

这是在导出中

            if($_POST["program"]=="dengue"){
      // get records from database
    $query = $db->query("SELECT * FROM lcho_dengue_activities ");

     if($query->num_rows > 0){
$delimiter = ",";
$filename = "dengueactivities" . date('Y-m-d') . ".csv";

//create a file pointer
$f = fopen('php://memory', 'w');


//output each row of the data, format =line as csv and write to file pointer
while($row = $query->fetch_assoc()){

    $lineData = array( $row['district_id'], $row['barangay_id'], $row['month'], $row['year'],$row['dengue_ind1'],$row['dengue_ind2'],$row['dengue_ind3'],$row['dengue_ind4'],$row['dengue_ind5'],$row['dengue_ind6'],$row['dengue_ind7'],$row['dengue_ind8'],$row['dengue_ind9'],$row['dengue_ind10'],$row['dengue_ind11'],$row['date']);

    fputcsv($f, $lineData, $delimiter);
}

//move back to beginning of file
fseek($f, 0);

//set headers to download file rather than displayed
header('Content-Type: text/csv');
header('Content-Disposition: attachment; filename="' . $filename . '";');

//output all remaining data on a file pointer
fpassthru($f);

} 退出;

需要具有相同的格式

1 个答案:

答案 0 :(得分:0)

您简而言之:

“出现问题,当我将表导出为csv文件并在excel上打开时:日期似乎具有不同的格式(在数据库中:yyyy-mm-dd,而在excel dd / mm上/ yyyy)”

似乎那只是野兽的天性。请记住,.csv文件不是Excel文件(它可能存储有关如何格式化所有内容的确切说明)。因此,当Excel打开.csv文件时,它会尝试对如何设置数据列的格式做出一些猜测,有时可能并不完全符合您的预期。

类似的东西试图显示2个小数位,而Excel则显示它认为重要的任何东西,例如0.12、0.13、0.1、0。 .csv文件中的内容为空白,则Excel似乎通常对如何正确设置列格式一无所知。

要真正准确地查看.csv文件中的内容,您可以使用某种文字处理器(例如编码编辑器)将其打开。