我逐行读取一个 txt 文件的内容,
但是每个文件第一行总是不能正确识别,
请问怎么做呢?
<code> $rTxt = fopen( $sTxt ,"r" ); while( $str = fgets($rTxt) ) { $arr = explode( ',' , $str ); Var_Dump( $arr[0] ); } fclose( $rTxt );</code>
txt 文件内容:
<code>1393592460,10680,10660,10650,10720,6040,3.227103E+08,0,0,108,4746,0,0 1393592520,10656,10697,10656,10701,4888,2.612444E+08,0,0,203,6858,0,0 1393592580,10697,10672,10672,10700,1294,6.911194E+07,0,0,281,7086,0,0 1393592640,10671,10667,10661,10675,1706,9.101747E+07,0,0,354,7590,0,0 1393592700,10669,10650,10648,10670,2340,1.246486E+08,0,0,448,8664,0,0 1393592760,10652,10640,10632,10656,1938,1.031578E+08,0,0,545,9282,0,0 1393592820,10641,10657,10641,10662,1746,9.297165E+07,0,0,631,8922,0,0 ......</code>
每次读取的时候,文件第一行的第一个数字长度总是不对,应该有个看不见的字符串..:
<code>string(13) "1393592460" string(10) "1393592520" string(10) "1393592580" string(10) "1393592640" </code>
回复内容:
我逐行读取一个 txt 文件的内容,
但是每个文件第一行总是不能正确识别,
请问怎么做呢?
<code> $rTxt = fopen( $sTxt ,"r" ); while( $str = fgets($rTxt) ) { $arr = explode( ',' , $str ); Var_Dump( $arr[0] ); } fclose( $rTxt );</code>
txt 文件内容:
<code>1393592460,10680,10660,10650,10720,6040,3.227103E+08,0,0,108,4746,0,0 1393592520,10656,10697,10656,10701,4888,2.612444E+08,0,0,203,6858,0,0 1393592580,10697,10672,10672,10700,1294,6.911194E+07,0,0,281,7086,0,0 1393592640,10671,10667,10661,10675,1706,9.101747E+07,0,0,354,7590,0,0 1393592700,10669,10650,10648,10670,2340,1.246486E+08,0,0,448,8664,0,0 1393592760,10652,10640,10632,10656,1938,1.031578E+08,0,0,545,9282,0,0 1393592820,10641,10657,10641,10662,1746,9.297165E+07,0,0,631,8922,0,0 ......</code>
每次读取的时候,文件第一行的第一个数字长度总是不对,应该有个看不见的字符串..:
<code>string(13) "1393592460" string(10) "1393592520" string(10) "1393592580" string(10) "1393592640" </code>
很有可能是utf8 bom字符。
引用 SO How to remove multiple UTF-8 BOM sequences
<code>//Remove UTF8 Bom function remove_utf8_bom($text) { $bom = pack('H*','EFBBBF'); $text = preg_replace("/^$bom/", '', $text); return $text; }</code>
用这个函数处理一下你的第一行应该就好了。
想知道更多关于BOM的知识:
知乎 - 「带 BOM 的 UTF-8」和「无 BOM 的 UTF-8」有什么区别
维基百科

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

查找方法:1、用strpos(),语法“strpos("字符串值","查找子串")+1”;2、用stripos(),语法“strpos("字符串值","查找子串")+1”。因为字符串是从0开始计数的,因此两个函数获取的位置需要进行加1处理。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

SublimeText3汉化版
中文版,非常好用

WebStorm Mac版
好用的JavaScript开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

SublimeText3 Linux新版
SublimeText3 Linux最新版