如何从CSV列创建句子

Har*_*ish 3 php csv input

我的目标是创建一个由三个随机单词组成的句子,这些单词将从CSV文件的列中获取.

让PHP只从正确的列中选择单词时遇到麻烦,因此第一列包含句子中第一个单词,第二列只包含中间单词,第三列只包含最后一个单词.

CSV文件的示例:

my;horse;runs
your;chicken;sits
our;dog;barks
Run Code Online (Sandbox Code Playgroud)

输出示例:

My chicken barks. *reload*
Your horse sits. *reload*
Our dog runs.
Run Code Online (Sandbox Code Playgroud)

到目前为止我的努力:

<?php
$file = fopen('input.csv', 'r');
while (($line = fgetcsv($file, 1000, ";")) !== FALSE) {
  $x = array_rand($line);
  echo $line[$x] . "\n";
}
?>
Run Code Online (Sandbox Code Playgroud)

请提前感谢并原谅这个强烈的noobness.

ark*_*cha 5

这按要求提供随机句子:

<?php
$file = fopen('input.csv', 'r');
// prepare token contained
$line = array();
// read csv file line by line
while (!feof($file))
    // fill single line into token container
    $line[] = fgetcsv($file, 1000, ";");
// construct a sentence by picking random words from columns
$sentence = sprintf("%s %s %s\n",
                    $line[rand(0,sizeof($line)-1)][0],
                    $line[rand(0,sizeof($line)-1)][1],
                    $line[rand(0,sizeof($line)-1)][2] );
// output sentence
echo $sentence;
?>
Run Code Online (Sandbox Code Playgroud)

但它效率不高,因为它首先将整个csv文件读入内存.所以它只在较小的csv文件上执行(比如最多几百行).对于较大的文件,您应该考虑首先选择随机行号并从文件中仅读取该行.这样做三次就会给你三个单词,你可以将你的句子整理出来.