将 php 中包含的 HTML 表单信息写入 CSV 文件

Posted

技术标签:

【中文标题】将 php 中包含的 HTML 表单信息写入 CSV 文件【英文标题】:Write HTML form info included in php, in a CSV file 【发布时间】:2019-03-23 08:11:33 【问题描述】:

我正在为自己的目的开发一个小型 Wordpress 插件。

第一步很简单,但是关于使用 php 将表单的数据写入 CSV 文件中,我有一些不明白的地方。 我正在使用 readfile() 在 PHP 文件中导入 html 代码。

我关注了这个tutorial,但我不明白为什么它不起作用。 CSV 文件中没有写入任何数据。 可能是因为 readfile()?

编辑:可能是因为我没有使用 Wordpress Hook 调用我的函数吗?发送表单时可以使用哪一个?

HTML 代码:

<form method="post">
    <label for="prenom">Prénom</label>
    <input class="main-content__form--input" pattern="[a-zA-Z0-9 ]+" id="prenom" type="text" name="prenom" required>

    <label for="nom">Nom</label>
    <input class="main-content__form--input" pattern="[a-zA-Z0-9 ]+" id="nom" type="text" name="nom" required>

    <label for="email">Email</label>
    <input class="main-content__form--input" id="email" type="email" name="email" required>

    <fieldset class="main-content__form--checkbox">
        <legend class="main-content__form--legend">Sélection des films</legend>

        <input type="checkbox" id="laHaine" name="films" value="La Haine">
        <label for="laHaine">La Haine</label>

        <input type="checkbox" id="odyssee" name="films" value="l'Odyssée de l'espace">
        <label for="odyssee">l'Odyssée de l'espace</label>

        <input type="checkbox" id="requiem" name="films" value="Requiem for a dream">
        <label for="requiem">Requiem for a dream</label>

        <input type="checkbox" id="mulholland" name="films" value="Mulholland Drive">
        <label for="mulholland">Mulholland Drive</label>

        <input type="checkbox" id="Carnage" name="films" value="Carnage">
        <label for="Carnage">Carnage</label>

        <input type="checkbox" id="under" name="films" value="Under the skin">
        <label for="under">Under the skin</label>

        <input type="checkbox" id="edward" name="films" value="Edward aux mains d'argent">
        <label for="edward">Edward aux mains d'argent</label>

        <input type="checkbox" id="lost" name="films" value="Lost in translation">
        <label for="lost">Lost in translation</label>
    </fieldset>

    <input class="main-content__form--input" name="submit" type="submit" value="S'inscrire">
</form>

PHP 代码:

$error = '';
$fname = sanitize_text_field($_POST['prenom']);
$lname = sanitize_text_field($_POST['nom']);
$email = sanitize_email($_POST['email']);
$checkbox = $_POST['films'];
$error = '';


function clean_text($clean) 
    $clean = trim($clean);
    $clean = stripslashes($clean);
    $clean = htmlspecialchars($clean);
    return $clean;



if(isset($_POST['submit'])) 

    if(empty($_POST['prenom']) OR empty($_POST['nom']) OR empty($_POST['email'])) 
        $error = '<p>Veuillez réessayer</p>';
         else 
        $fname = clean_text($_POST['prenom']);
        $lname = clean_text($_POST['nom']);
        $email = clean_text($_POST['email']);
        

        if($error = '') 
            $file_open = fopen('../form-to-csv.csv', 'a');
            $no_rows = count(file('form-to-csv.csv')); 
            if ($no_rows > 1) 
                $no_rows = ($no_rows - 1) +1;
             
            $form_data = array(
            'id' => $no_rows,
            'prenom' => $fname,
            'nom' => $lname,
            'email' => $email,
            'films' => $checkbox
        );
            fputcsv($file_open, $form_data);
            $error = '<p>Votre inscription a bien été prise en compte</p>';
            $fname = '';
            $lname = '';
            $email = '';
            $checkbox = '';
                     

【问题讨论】:

您的代码有哪些“不起作用”的地方?具体发生了什么?它是如何失败的? 怀疑是不是问题,但是 - 你 fopen() '../form-to-csv.csv' 但计算来自 'form-to-csv.csv' 的行,这将是两个不同的文件。也不确定$no_rows = ($no_rows - 1) +1;的目的 @David csv 文件中没有写入任何信息。我是 PHP 新手(使用更多 JS)并且不知道如何调试它)。对不起。 @NigelRen 我不明白这些台词。 更新了我的答案。 【参考方案1】:

比较运算符中的错字:if($error = '') 应为 if($error == '')

编辑:这可能是您的文件权限,尤其是编辑。更改权限或尝试将 csv 文件放在桌面上:$file_open = fopen('C:\Users\Daniel\Desktop\form-to-csv.csv', 'a');

编辑 2: 是的,它是文件权限。我用固定的比较运算符执行了你的代码,它成功地附加到了文件中。

【讨论】:

@Danier Visser 谢谢,我更正了它,但它仍然不起作用。 CSV 文件中没有写入任何信息。 @Danier Visser,这就是问题所在。我无法摆脱 Wordpress 插件文件夹的“只读”。我将 CSV 文件放在桌面上。谢谢。

以上是关于将 php 中包含的 HTML 表单信息写入 CSV 文件的主要内容,如果未能解决你的问题,请参考以下文章

如何验证脚手架中包含的 bottomSheet 内的表单?

21PHP 表单验证

在 PHP 中提取 XML 中包含的一些 JSON

如何引用文本框中包含的文本来创建 XML 文件?

php之表单-2(表单验证)

php PHP:获取我的images目录中包含的所有文件名列表[重复]