12

我正在尝试将现有数据从 MySQL 数据库导出到可以运行的 ruby​​ 命令中rake db:seed

这是我的代码。

# Generate db:seed data for proveedores.
$proveedores = R::findAll('tbproveedores');
$proveedoresE = R::exportAll($proveedores);

foreach ($proveedoresE as &$p) {

    $line = 'BookSupplier.create(company: "%s", city: "%s", country: "%s", address: "%s", telephone: "%s", contact: "%s", email: "%s", website: "%s"\n';
    $exportedLine = sprintf($line, $p['empresa'], $p['ciudad'], $p['pais'], $p['direccion'], $p['telefono'], $p['personacontacto'], $p['email'], $p['website']);
    var_dump($exportedLine);
    fwrite($seeds, $exportedLine);
    echo "<br />";
}

注意\n$line 变量末尾的换行符。我在网上读到这就是使用换行符所需的全部内容。

我上面的代码的输出是(逐字,很长的一行):

BookSupplier.create(company: "Pearson", city: "Lima", country: "Peru", address: "Av. Limon", telephone: "4673535421", contact: "Javier", email: "", website: ""\nBookSupplier.create(company: "Project Management Institute - PMI", city: "Pennsylvania", country: "Estados Unidos", address: "Newtown Square, Pennsylvania", telephone: "1", contact: "Limberg Morales", email: "", website: "http://www.pmi.org/"\nBookSupplier.create(company: "UVirtual - Centro de Excelencia", city: "Santa Cruz", country: "Bolivia", address: "Av. Irala 585", telephone: "1", contact: "Limberg Morales", email: "", website: ""\nBookSupplier.create(company: "Ábaco de Rodolfo Depalma", city: "Buenos Aires", country: "Argentina", address: "Viamonte 1336, 4° (C1053 ACB) Buenos Aires", telephone: "5411-43711675", contact: "Limberg Morales", email: "", website: "http://www.abacoeditorial.com.ar/"\nBookSupplier.create(company: "Pablo Lledó - ProjectManagement", city: "Canadá", country: "Estados Unidos", address: "Victoria, BC, Canadá", telephone: "1", contact: "Limberg Morales", email: "", website: ""\n

在我插入换行符之后,我希望每个调用都在它自己的行中。关于我做错了什么有什么建议吗?

4

6 回答 6

33

只有用双引号括起来的换行符\n才会被解释: . 像那样:"

$line  = '...............';
$line .= "\n";

您还应该了解PHP_EOL它是一个常量,其中包含系统换行符分隔符,这在几个操作系统上是不同的。例如,它将\n在 Linux 上但\r\n在 Windows 上。最便携的代码如下所示:

$line  = '.....';
$line .= PHP_EOL;
于 2013-02-26T14:41:14.440 回答
16

如果您不能(或不想)切换到双引号,则可以使用 ASCII 代码插入换行符,如下所示:

> php
<?php printf('line one%cline two', 10);^D
line one
line two
>

允许您插入任何 ASCII 代码,而%c10 是换行符的代码。

于 2013-09-29T23:34:11.143 回答
5

您需要使用双引号字符串,单引号不扩展特殊字符序列。查看手册以获取有关 PHP 字符串的更多详细信息。

于 2013-02-26T14:42:45.367 回答
2

字符串中的特殊字符仅在用双引号 (") 括起来时才有效。有关详细信息,请参阅PHP 字符串文档

所以要么使用双引号,这需要大量的工作,因为你在字符串中也使用了很多双引号。并转义字符串内的所有双引号。

或者,如果您很懒惰,请在之后连​​接新行:

$line = '...';
$line .= "\n";
于 2013-02-26T14:41:42.230 回答
2

继 Josh 的回答之后,您可以使用 %s 将插值字符串中的换行符注入 printf 中printf('something%s', "\n"),这在更复杂的示例中开始变得更有意义 - 例如,如果字符串模板存储在语言变量中,或者您正在执行多个替换,或者只需要坚持使用 sprintf,因为您的 PHB 要求它。

在你的情况下,它会是

$line = 'BookSupplier.create(company: "%s", city: "%s", country: "%s", address: "%s", telephone: "%s", contact: "%s", email: "%s", website: "%s"%s';
$exportedLine = sprintf($line, $p['empresa'], $p['ciudad'], $p['pais'], $p['direccion'], $p['telefono'], $p['personacontacto'], $p['email'], $p['website'], "\n");

我已经格式化了一个电子邮件标题块:

$headers = sprintf(
    'From: %1$s%2$sReply-To: %1$s%2$sMIME-Version: 1.0%2$sContent-type: text/html; charset=iso-8859-1%2$s'
    , $EMAIL_FROM, "\r\n");

重复使用\r\n使用1$参数索引语法。

所以%2$s变成了新的\r\n,不占用任何额外的字符,但更难阅读!

于 2015-03-24T11:08:05.990 回答
0
$line = "BookSupplier.create(company: '%s', city: '%s', country: '%s', address: '%s', telephone: '%s', contact: '%s', email: '%s', website: '%s'\n";

\n(或任何其他 whitescpace char 如 \t)必须使用双引号才能工作。

于 2013-02-26T14:41:24.973 回答