使用php

时间:2018-10-31 08:22:15

标签: php html mysql

请帮助我改善代码。我有此html表单,仅选择.csv文件扩展名,以将其上传到我的sql数据库中。我该如何改善?例如,如果没有选择文件,则使按钮不可单击。

<form class="ui input" enctype="multipart/form-data" method = "POST" role = "form">
  <input type = "file" name ="file" id="file" size = "150">
  <button class="ui small red button" type = "submit" class = "btn btn-default" name ="submit"  value = "submit">Upload CSV</button> 
</form>

然后这是我的php代码,用于上传csv,如何显示“您的文件正在上传,请稍候”和“完成上传”的弹出消息。我的问题是我的csv文件的标头也上传了,如何排除csv的第一行?

<?php

if(isset($_POST['submit'])) {
    $host = 'localhost';
    $user = 'root';
    $password = '';
    $db = 'jeremy_db';

    $con = mysqli_connect($host,$user,$password) or die('Could not' .mysqli_error($con));

    mysqli_select_db($con, $db) or die ('Could not' .mysqli_error($con));

    $file = $_FILES['file']['tmp_name'];
    $handle = fopen($file, "r");

    $c = 0;

    while(($csvdata = fgetcsv($handle,1000,","))!== FALSE){
        $sha1 = $csvdata[0];
        $vsdt = $csvdata[1];
        $trendx  = $csvdata[2];

        $sql = "INSERT INTO jeremy_table_trend (sha1,vsdt,trendx) VALUES ('$sha1','$vsdt','$trendx')";
        $query = mysqli_query($con , $sql);

        $c = $c+1;
    }
    if($query){
        echo "SABRE";
    }
    else { 
        echo "SLAM";
    }
}
?>

我正在使用php 7个人,有什么建议吗?

1 个答案:

答案 0 :(得分:0)

最初,您可以禁用“提交”按钮。然后单击以输入文件,您可以调用js函数,该函数将验证文件扩展名并相应地启用提交按钮。

用于显示消息-您可以编写JavaScript函数onclick提交按钮。

对于动态处理大文件,这不是一个好习惯。执行所有查询都会超时(查询数= csv中的行数)。您可以按照以下步骤操作-

  1. 首先将csv文件上传到服务器
  2. 创建一个存储过程(将上传的文件路径传递到此过程),该过程会将csv文件加载到数据库中。您可以在此处获取帮助以加载文件-https://dev.mysql.com/doc/refman/8.0/en/load-data.html
  3. 要排除标题,您将在上面的链接中获得说明