0

我创建了一个表单,该表单利用 .txt 文件从中提取 EMPLOYEES 的名称,并使用 PHP 分解函数在 SELECT 表单选项中将它们分解。

<select name="FakeName" id="Fake-ID" aria-required="true" required>
 <option value=""></option>
  <?php
   $options=nl2br(file_get_contents("employees.txt"));
   $options=explode("<br />",$options);

   for($i=0;$i<count($options);$i++)
   {
    echo "<option value='".$options[$i]."'>".$options[$i]."</option>";
   }
 ?>
</select>

.txt 文件如下所示:

Name 1
Name 2
Name 3
ETC

现在,这可以在网站上的表单中正常工作,并正确分解,一切看起来都很好。但是,当结果提交到电子表格(在本例中为 GOOGLE 电子表格)时,输出包括“中断”,因此它以类似于以下格式进入电子表格:

Row 1: Name 1
Row 2:
       Name 2
Row 3:
       Name 3
Row 4:
       ETC

我试图弄清楚如何更改代码或其他内容,以便分隔符本身不会作为结果的一部分提交。注意:使用任何分隔符提交。我试过“\”或“;” 并提交结果。

4

3 回答 3

0

您可以尝试一种不同的方法,例如逐行读取文件,而不是处理所有这些 nl2br / explode 的东西。

$fh = fopen("employees.txt", "r");
if ($fh) {
    while (($line = fgets($fh)) !== false) {
        $line = trim($line);
        echo "<option value='".$line."'>".$line."</option>";
    }
} else {
    // error opening the file, do something
}

也可能只是做一个修剪(从字符串的开头/结尾删除空格)是你的问题吗?

也许人们只是误解了你所说的“将结果提交到电子表格”的意思——你是用代码做的吗?还是从 HTML 页面复制/粘贴到电子表格中?也许你可以更详细地解释一下。无论如何,您分割文件行的分隔符不应该显示在输出中,除非您出于其他原因有意外的输出。

于 2013-12-31T22:40:45.727 回答
0
<select name="FakeName" id="Fake-ID" aria-required="true" required>

<?php
$options=nl2br(file_get_contents("employees.txt"));
$options=explode("<br />",$options); 
foreach ($options as $item_array)
{
echo "<option value='".$item_array"'>".$item_array"</option>";
 }
?>
</select>
于 2013-12-31T22:25:47.613 回答
0

不要使用 nl2br() 添加换行符,然后使用 explode() 删除换行符,而是尝试使用换行符 '\r' 或 '\n' 或 '\r\n'。

<?php
    $options= file_get_contents("employees.txt");
    $options=explode("\n",$options);        // try \r as well.

    foreach ($options as $singleOption){
        echo "<option value='".$singleOption."'>".$singleOption."</option>";
    }

 ?>

如果问题是由于 Google 电子表格读取换行符造成的,这也可以解决问题。

于 2013-12-31T22:35:25.647 回答