PHP生成excel時(shí)單元格內(nèi)換行問(wèn)題的解決方法
更新時(shí)間:2010年08月26日 00:38:37 作者:
今天 客戶提問(wèn)題說(shuō),導(dǎo)出的excel文件,該換行的單元格沒(méi)有換行。通過(guò)查找資源找到了解決方法。
翻出來(lái)源碼開(kāi)了下,字符串中使用換行的方法為"Name:{$name}\nAddress:{$adress}\nCity:{$city}\nCountry:{$country}\n ......"
既然"\n"起不到換行的目的,修改成"\r\n"看看.
修改 =》 提交 =》測(cè)試
得出的結(jié)果還是 沒(méi)有換行?。。?!
難道是操作系統(tǒng)兼容問(wèn)題??
直接使用php runtime 常量 PHP_EOL 替代 "\r\n"
修改 =》 提交 =》測(cè)試
得出的結(jié)果還是 沒(méi)有換行!?。?!
什么情況? 不可能這個(gè)也解決不了 操作系統(tǒng)兼容性問(wèn)題的換行符號(hào)。
看看到底這個(gè)xls文件是怎么用php生成的。
看了下 生成excel的代碼,Oh My Lady gaga,原來(lái)是用html的格式,只是文件后綴寫(xiě)成xls,既然html的格式,那么應(yīng)該<br />可以起到換行的效果吧。
繼續(xù)
修改 =》 提交 =》測(cè)試
結(jié)果是 可以換行了。 可喜可賀啊。問(wèn)題終于解決了。
告訴老大問(wèn)題解決,此時(shí)心中甚是喜悅啊。
過(guò)了一刻鐘的樣子,老大跑過(guò)來(lái)說(shuō):“換行效果的問(wèn)題是解決了,但是你看下,數(shù)據(jù)不好復(fù)制了?!?
。。。。
省略溝通N句。
把一個(gè)單元格的數(shù)據(jù)復(fù)制下,然后 粘貼到 word中。Oh My Lady gaga, 為啥會(huì)有border????
到底什么問(wèn)題?? 使用\n、\r\n 把不能起到換行的相關(guān),使用<br />把效果是有了,但是又出現(xiàn)了新問(wèn)題。。。 到底如何是好?
沒(méi)轍了,使用BAIDU google吧。
終于 黃天不負(fù)有心人,找到了問(wèn)題的答案。
在<style></styel>標(biāo)簽中追加 CSS樣式br {mso-data-placement:same-cell;}
終于 問(wèn)題 完美解決。
原文如下:
將HTML文件的擴(kuò)展名改為XLS后,用Excel打開(kāi),里邊的每個(gè)<br />都會(huì)使后邊的文字進(jìn)入另一個(gè)單元格,要使<br />在一個(gè)單元格內(nèi)起到換行的作用,可以在CSS里加入這一句:
br {mso-data-placement:same-cell;}
Excel就會(huì)把<br />解釋成回車(chē)了。
在此多謝“卡卡西的真面目” 這位仁兄 把 知識(shí)分享出來(lái)。 要不然的話,不知道我還要折騰到什么時(shí)候才能解決?。?
既然"\n"起不到換行的目的,修改成"\r\n"看看.
修改 =》 提交 =》測(cè)試
得出的結(jié)果還是 沒(méi)有換行?。。?!
難道是操作系統(tǒng)兼容問(wèn)題??
直接使用php runtime 常量 PHP_EOL 替代 "\r\n"
修改 =》 提交 =》測(cè)試
得出的結(jié)果還是 沒(méi)有換行!?。?!
什么情況? 不可能這個(gè)也解決不了 操作系統(tǒng)兼容性問(wèn)題的換行符號(hào)。
看看到底這個(gè)xls文件是怎么用php生成的。
看了下 生成excel的代碼,Oh My Lady gaga,原來(lái)是用html的格式,只是文件后綴寫(xiě)成xls,既然html的格式,那么應(yīng)該<br />可以起到換行的效果吧。
繼續(xù)
修改 =》 提交 =》測(cè)試
結(jié)果是 可以換行了。 可喜可賀啊。問(wèn)題終于解決了。
告訴老大問(wèn)題解決,此時(shí)心中甚是喜悅啊。
過(guò)了一刻鐘的樣子,老大跑過(guò)來(lái)說(shuō):“換行效果的問(wèn)題是解決了,但是你看下,數(shù)據(jù)不好復(fù)制了?!?
。。。。
省略溝通N句。
把一個(gè)單元格的數(shù)據(jù)復(fù)制下,然后 粘貼到 word中。Oh My Lady gaga, 為啥會(huì)有border????
到底什么問(wèn)題?? 使用\n、\r\n 把不能起到換行的相關(guān),使用<br />把效果是有了,但是又出現(xiàn)了新問(wèn)題。。。 到底如何是好?
沒(méi)轍了,使用BAIDU google吧。
終于 黃天不負(fù)有心人,找到了問(wèn)題的答案。
在<style></styel>標(biāo)簽中追加 CSS樣式br {mso-data-placement:same-cell;}
終于 問(wèn)題 完美解決。
原文如下:
復(fù)制代碼 代碼如下:
將HTML文件的擴(kuò)展名改為XLS后,用Excel打開(kāi),里邊的每個(gè)<br />都會(huì)使后邊的文字進(jìn)入另一個(gè)單元格,要使<br />在一個(gè)單元格內(nèi)起到換行的作用,可以在CSS里加入這一句:
br {mso-data-placement:same-cell;}
Excel就會(huì)把<br />解釋成回車(chē)了。
在此多謝“卡卡西的真面目” 這位仁兄 把 知識(shí)分享出來(lái)。 要不然的話,不知道我還要折騰到什么時(shí)候才能解決?。?
相關(guān)文章
PHP入門(mén)教程之字符串處理技巧總結(jié)(轉(zhuǎn)換,過(guò)濾,解析,查找,截取,替換等)
這篇文章主要介紹了PHP入門(mén)教程之字符串處理技巧,結(jié)合實(shí)例形式總結(jié)分析了php針對(duì)字符串的刪除空格、特殊字符轉(zhuǎn)換、過(guò)濾、解析、分割、查找、截取、替換、獲取、判斷、計(jì)算等操作技巧,需要的朋友可以參考下2016-09-09
PHP詳解ASCII碼對(duì)照表與字符轉(zhuǎn)換
PHP基礎(chǔ)篇詳解ASCII碼對(duì)照表與字符轉(zhuǎn)換,討論ASCII碼對(duì)照表圖與字符轉(zhuǎn)換為十進(jìn)制、八進(jìn)制、十六進(jìn)制和HTML的方法2011-12-12
PHP實(shí)現(xiàn)本地圖片轉(zhuǎn)base64格式并上傳
這篇文章主要介紹了PHP實(shí)現(xiàn)本地圖片轉(zhuǎn)base64格式并上傳,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05
php讀取圖片內(nèi)容并輸出到瀏覽器的實(shí)現(xiàn)代碼
如果php以圖片,zip,exe等文件輸出到瀏覽器,而前面還輸出了其他字符,那就會(huì)是你看到的亂碼2013-08-08

