将php中包含的HTML表单信息写入CSV文件
我正在为自己的目的开发一个小的Wordpress插件 第一步很简单,但对于使用PHP在CSV文件中写入表单数据,我有一些不理解的地方。 我使用readfile()在PHP文件中导入html代码 我遵循这一点,但我不明白为什么它不起作用。CSV文件中未写入任何数据。 可能是因为readfile()的缘故吗 编辑:可能是因为我没有用Wordpress钩子调用我的函数吗?在发送表单时可以使用哪一个 HTML代码:将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
<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:是的,这是文件权限。我使用修复的比较运算符执行了您的代码,并成功地将其附加到文件中。您的代码有什么“不起作用”的地方?具体发生了什么,以及它是如何失败的?怀疑这是否是问题所在,但是-youfopen()
'../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文件放在桌面上。谢谢。