将 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 文件的主要内容,如果未能解决你的问题,请参考以下文章