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

将php中包含的HTML表单信息写入CSV文件,php,html,wordpress,forms,csv,Php,Html,Wordpress,Forms,Csv,我正在为自己的目的开发一个小的Wordpress插件 第一步很简单,但对于使用PHP在CSV文件中写入表单数据,我有一些不理解的地方。 我使用readfile()在PHP文件中导入html代码 我遵循这一点,但我不明白为什么它不起作用。CSV文件中未写入任何数据。 可能是因为readfile()的缘故吗 编辑:可能是因为我没有用Wordpress钩子调用我的函数吗?在发送表单时可以使用哪一个 HTML代码: <form method="post"> <label for

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

第一步很简单,但对于使用PHP在CSV文件中写入表单数据,我有一些不理解的地方。 我使用readfile()在PHP文件中导入html代码

我遵循这一点,但我不明白为什么它不起作用。CSV文件中未写入任何数据。 可能是因为readfile()的缘故吗

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

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 = '';
        }             
}
$error='';
$fname=sanitize_text_字段($_POST['prenom']);
$lname=sanitize_text_字段($_POST['nom']);
$email=sanitize_email($_POST['email']);
$checkbox=$_POST['films'];
$error='';
函数clean_text($clean){
$clean=修剪($clean);
$clean=stripslashes($clean);
$clean=htmlspecialchars($clean);
退回$clean;
}
如果(isset($_POST['submit'])){
如果(空($_POST['prenom'])或空($_POST['nom'])或空($_POST['email'])){
$error='Veuillez réessayer

'; }否则{ $fname=clean_text($_POST['prenom']); $lname=clean_text($_POST['nom']); $email=clean_text($_POST['email']); } 如果($error=''){ $file_open=fopen('../form to csv.csv','a'); $no_rows=count(文件('form-to-csv.csv'); 如果($no_rows>1){ $no_rows=($no_rows-1)+1; } $form_data=数组( 'id'=>$no\u行, “prenom”=>$fname, “nom”=>$lname, “email”=>$email, “电影”=>$checkbox ); fputcsv($file\u open,$form\u data); $error='Votre铭文一个完整的价格

'; $fname=''; $lname=''; $email=''; $checkbox=''; } }
比较运算符中的键入:
if($error=''){
应该是
if($error=''){

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


编辑2:是的,这是文件权限。我使用修复的比较运算符执行了您的代码,并成功地将其附加到文件中。

您的代码有什么“不起作用”的地方?具体发生了什么,以及它是如何失败的?怀疑这是否是问题所在,但是-you
fopen()
'../form to csv.csv'
但是计算一下从
'form-to-csv.csv'
到两个不同文件的行数。也不确定
$no_rows=($no_rows-1)+1的用途;
@David csv文件中没有写入任何信息。我对PHP不熟悉(使用更多JS)抱歉。@NigelRen我不理解这些行。更新了我的答案。@Danier Visser谢谢,我更正了它,但仍然不起作用。CSV文件中没有写入任何信息。@Danier Visser,这就是问题所在。我无法摆脱Wordpress插件文件夹的“只读”。我将CSV文件放在桌面上。谢谢。