草庐IT

php - 在csv php中转义换行符

coder 2024-05-04 原文

我有一个 .csv 模板,希望人们填写、保存并上传。

问题是这样的,假设一些用户会在一行中插入隐藏换行符,当使用 fgetcsv() 时它会输出被隐藏换行符打断的行。

如何避免换行符或清理我的数据?

可能的解决方案:

假设第一行是正确的,$count = 计算分隔符的个数直到换行,将文本重建成数组只要$count;

但我认为还有更好的选择。

后期编辑

这是输入*重要[! ] :excel 文件中的数据“很好”,没有损坏,是单行!!!保存为csv文件用记事本打开显示如下

asd;"asd
asd
asd";asd;asd

这是代码

$handle = fopen("file.csv","r");
$data = fgetcsv($handle,";");
while($data = fgetcsv($handle)) {
    $array = explode(";",$data[0]);
    print_r($array);
}
fclose($handle);

这是回显数据

Array ( [0] => asd [1] => "asd ) Array ( [0] => asd ) Array ( [0] => asd" [1] => asd [2] => asd [3] => ) 

谢谢

最佳答案

如果字段被正确引用,测试您的案例并查看没有断行非常容易。

所以,像这样的 CSV 行

1,"joe
""Big Coyote""
Hopkins",598600

将毫无问题地阅读。

关于php - 在csv php中转义换行符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7711589/

有关php - 在csv php中转义换行符的更多相关文章

  1. ruby - 如何使用文字标量样式在 YAML 中转储字符串? - 2

    我有一大串格式化数据(例如JSON),我想使用Psychinruby​​同时保留格式转储到YAML。基本上,我希望JSON使用literalstyle出现在YAML中:---json:|{"page":1,"results":["item","another"],"total_pages":0}但是,当我使用YAML.dump时,它不使用文字样式。我得到这样的东西:---json:!"{\n\"page\":1,\n\"results\":[\n\"item\",\"another\"\n],\n\"total_pages\":0\n}\n"我如何告诉Psych以想要的样式转储标量?解

  2. ruby - 如何在ruby中转换为big endian - 2

    我有一个小端顺序的字符串,作为十六进制编码的字符串000000020597ba1f0cd423b2a3abb0259a54ee5f783077a4ad45fb6200000218000000008348d1339e6797e2b15e9a3f2fb7da08768e99f02727e4227e02903e43a42b31511553101a051f3c00000000000000800000000000000000000000000000000000000000000000000000000000000000000000000000000080020000我想将每个32位block从l

  3. ruby-on-rails - 在 fastercsv 中转义逗号值 - 2

    我正在研究csv生成。我正在分隔由逗号(,)分隔的值。如果字段中的值包含逗号,则不应在excel中分隔该字段。所以我想在那里放一个转义字符。我正在使用FasterCsv。那么我如何放置转义字符。fastercsv的转义字符是什么? 最佳答案 只需引用每个字段(默认为双引号),其中的逗号将被忽略:CSV.generate(:col_sep=>',',:quote_char=>'"')do|row|row"\"Quid,quid\",latinumdictum\n\"sit,altum\",viditur.\n"

  4. ruby - 代码块中的 Markdown 换行符 - 2

    使用Redcarpet,当我在Markdown中包含类似以下内容时,它不考虑任何换行符或缩进。我在行尾尝试了两个空格。代码之间的额外行。似乎没有任何效果。```xml3```我明白了:3这里是Redcarpet设置:Redcarpet::Markdown.new(Redcarpet::Render::HTML,:autolink=>true,:space_after_headers=>true,:fenced_code_blocks=>true,:no_intra_emphasis=>true,:lax_html_blocks=>true)我需要做什么才能正确换行并保留缩进,就像这里或

  5. Ruby 无法检测字符串中的换行符 - 2

    我有以下字符串,我想检测那里的换行符。但是Ruby的字符串方法include?检测不到它。我正在运行Ruby1.9.2p290。我哪里出错了?"/'ædres/\nYour".include?('\n')=>false 最佳答案 \n需要在双引号内,否则无法转义。>>"\n".include?'\n'=>false>>"\n".include?"\n"=>true 关于Ruby无法检测字符串中的换行符,我们在StackOverflow上找到一个类似的问题: h

  6. ruby-on-rails - 这个 C 和 PHP 程序员如何学习 Ruby 和 Rails? - 2

    按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。我来自C、php和bash背景,很容易学习,因为它们都有相同的C结构,我可以将其与我已经知道的联系起来。然后2年前我学了Python并且学得很好,Python对我来说比Ruby更容易学。然后从去年开始,我一直在尝试学习Ruby,然后是Rails,我承认,直到现在我还是学不会,讽刺的是那些打着简单易学的烙印,但是对于我这样一个老练的程序员来说,我只是无法将它

  7. ruby - 换行位置 - 2

    给定一个字符串,返回字符串中换行符开头的字符位置数组的最有效方法是什么?text=预期:find_newlines(text)#=>[0,80,155,233,313,393]我发布我自己的答案。我愿意接受最快的方式作为接受的答案。此处的基准测试结果将在添加新答案时更新require"fruity"comparedopadde1{find_newlines_padde1(text)}digitalross1{find_newlines_digitalross1(text)}sawa1{find_newlines1(text)}sawa2{find_newlines2(text)}end

  8. ruby-on-rails - 换行符在 Sendgrid X-SMTPAPI header 中解析为 =0A - 2

    我正在使用Sendgrid将电子邮件发送到邮件列表,使用X-SMTPAPIheader指定多个收件人。来自Sendgriddocumentation“header必须换行以将行长度保持在72以下。”我正在使用ActionMailer发送电子邮件,并使用headers方法设置X-SMTPAPIheader。为了保持行少于72个字符,我尝试用逗号+换行符+空格替换每个逗号。例如,headers["X-SMTPAPI"]={:to=>['user1@example.com','user2@example.com','user3@example.com','user4@example.com'

  9. ruby - 为什么括号内的换行符会改变算术结果? - 2

    为什么下面的表达式会这样解析?括号的优先级应该高于换行符,不是吗?3-(1+1)#=>13-(1+1)#=>2省略加号也会让表达式计算为2:3-(11)#=>2如果我声明为连续的换行符(转义)或将加号移动到第一行,则会实现所需的行为:3-(1\+1)#=>13-(1+1)#=>1 最佳答案 这是因为Ruby将新行识别为表达式的结尾,除非表达式不完整。例如,(1+1)与相同(1;+1)这与+1相同,因为返回了括号内的最后一个表达式。这进一步与1相同。如果行尾有+,则表达式不完整,因此会继续到下一行。这使得:3-(1+1)被解释为3-(

  10. ruby gsub 换行符 - 2

    我有一个包含换行符的字符串,我想用gsub替换空白。"helloI\r\namatest\r\n\r\nstring".gsub(/[\\r\\n]/,'')类似这样的事情^只有我的正则表达式似乎也在替换'r'和'n'字母。另一个约束是有时模式会重复两次,因此会被一行中的两个空格替换,尽管这不是可取的,但比所有文本都被切开要好。如果有办法只选择换行符。或者,如果在使用正则表达式之外还有更简单的方法来解决这个问题,那就更好了? 最佳答案 如果您有混合的连续换行符并想用单个空格替换,您可以使用以下正则表达式解决方案:s.gsub(/\R

随机推荐