亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

HTML轉(zhuǎn)義字符&npsp;表示non-breaking space \xa0

 更新時間:2020年02月23日 16:59:54   作者:my8100  
HTML轉(zhuǎn)義字符&npsp;表示non-breaking space,unicode編碼為u'\xa0',超出gbk編碼范圍,這里就為大家分享一下

1.參考

Beautiful Soup and Unicode Problems

詳細(xì)解釋

unicodedata.normalize('NFKD',string) 實際作用???

Scrapy : Select tag with non-breaking space with xpath

>>> selector.xpath(u'''
... //p[normalize-space()]
... [not(contains(normalize-space(), "\u00a0"))]

normalize-space() 實際作用???

In [244]: sel.css('.content')
Out[244]: [<Selector xpath=u"descendant-or-self::*[@class and contains(concat(' ', normalize-space(@class), ' '), ' content ')]" data=u'<p class="content text-

BeautifulSoup下Unicode亂碼解決

今天在用scrapy爬某個網(wǎng)站的數(shù)據(jù),其中DOM解析我用的是BeautifulSoup,速度上沒有XPath來得快,不過因為用了習(xí)慣了,所以一直用的bs,版本是bs4
不過在爬取過程中遇到了一些問題,其中一個是Unicode轉(zhuǎn)碼問題,這也算是python中一個著名問題了。
我遇到的算是BeautifulSoup中的一個奇葩bug吧,在網(wǎng)頁中經(jīng)常會有 &nbsp 這種標(biāo)記,稱為 non-breaking space character, 本來這個應(yīng)該是忽略的,但在bs中會把這個符號
轉(zhuǎn)義成為一個unicode編碼 \xa0, 這就導(dǎo)致了后面如果要對內(nèi)容處理的話會出現(xiàn)UnicodeError, 特別是如果使用的是Console或者scrapy中寫文件、寫數(shù)據(jù)庫的pipeline操作時,
出現(xiàn)無法轉(zhuǎn)義的錯誤。
那么該如何解決呢,其實不難

s = u'\xa0'
s.replace(u'\xa0', u'')

之后就可以對s進(jìn)行encode,比如:

s = u'\xa0'
s.replace(u'\xa0', u'').encode('utf-8')

特別是在我的項目中,如果需要把數(shù)據(jù)寫到MongoDB中,這個bug fix完后,寫數(shù)據(jù)立刻搞定,爬取的內(nèi)容全部寫到MongoDB中。

s.replace(u'\xa0', u'').encode('utf-8')

2.問題定位

https://en.wikipedia.org/wiki/Comparison_of_text_editors

定位元素顯示為 &npsp;

網(wǎng)頁源代碼表示為 &#160;

<tr>
<td style="background: #FFD; color: black; vertical-align: middle; text-align: center;" class="partial table-partial">memory</td>
<td>= Limited by available memory &#160;&#160;</td>
<td style="background:#F99;vertical-align:middle;text-align:center;" class="table-no">No (64&#160;KB)</td>
<td>= Some limit less than available memory (give max size if known)</td>
</tr>
</table>

實際傳輸Hex為:

不間斷空格的unicode表示為 u\xa0',保存的時候編碼 utf-8 則是 '\xc2\xa0'

In [211]: for tr in response.xpath('//table[8]/tr[2]'):
...: print [u''.join(i.xpath('.//text()').extract()) for i in tr.xpath('./*')]
...:

[u'memory', u'= Limited by available memory \xa0\xa0', u'No (64\xa0KB)', u'= Some limit less than available memory (give max size if known)']

In [212]: u'No (64\xa0KB)'.encode('utf-8')
Out[212]: 'No (64\xc2\xa0KB)'

In [213]: u'No (64\xa0KB)'.encode('utf-8').decode('utf-8')
Out[213]: u'No (64\xa0KB)'

保存 csv 直接使用 excel 打開會有亂碼(默認(rèn)ANSI gbk 打開???,u'\xa0' 超出 gbk 能夠編碼范圍???),使用記事本或notepad++能夠自動以 utf-8 正常打開。

使用記事本打開csv文件,另存為 ANSI 編碼,之后 excel 正常打開。超出 gbk 編碼范圍的替換為'?'

3.如何處理

.extract_first().replace(u'\xa0', u' ').strip().encode('utf-8','replace')

以上就是HTML轉(zhuǎn)義字符&npsp;表示non-breaking space \xa0的詳細(xì)內(nèi)容,更多關(guān)于HTML轉(zhuǎn)義字符\xa0的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Git常用命令及如何在IDEA中使用Git詳解

    Git常用命令及如何在IDEA中使用Git詳解

    Git有很多客戶端工具,不過感覺還是命令行操作最好用,方便又快捷,下面這篇文章主要給大家介紹了關(guān)于Git常用命令及如何在IDEA中使用Git的相關(guān)資料,需要的朋友可以參考下
    2023-02-02
  • 淺談Git分支管理策略

    淺談Git分支管理策略

    這篇文章主要介紹了淺談Git分支管理策略,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • Git rebase命令使用實戰(zhàn)

    Git rebase命令使用實戰(zhàn)

    這篇文章主要介紹了Git rebase命令使用實戰(zhàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • VSCode中通過launch.json文件打斷點DeBug調(diào)試代碼詳細(xì)圖文教程

    VSCode中通過launch.json文件打斷點DeBug調(diào)試代碼詳細(xì)圖文教程

    在VSCode中l(wèi)aunch.json是用于配置調(diào)試器的文件,它定義了調(diào)試會話的各種設(shè)置,下面這篇文章主要給大家介紹了關(guān)于VSCode中通過launch.json文件打斷點DeBug調(diào)試代碼的詳細(xì)圖文教程,需要的朋友可以參考下
    2024-08-08
  • git中commit和push的區(qū)別及說明

    git中commit和push的區(qū)別及說明

    這篇文章主要介紹了git中commit和push的區(qū)別及說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • 如何用idea+gitee來團(tuán)隊合作開發(fā)項目的教程

    如何用idea+gitee來團(tuán)隊合作開發(fā)項目的教程

    這篇文章主要介紹了如何用idea+gitee來團(tuán)隊合作開發(fā)項目,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-08-08
  • Wireshark TS FTP 傳輸失敗問題解決

    Wireshark TS FTP 傳輸失敗問題解決

    這篇文章主要為大家介紹了Wireshark TS FTP 傳輸失敗問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03
  • 兩分鐘學(xué)會如何在github托管代碼

    兩分鐘學(xué)會如何在github托管代碼

    這篇文章主要介紹了兩分鐘學(xué)會如何在github托管代碼,本篇內(nèi)容針對不會Git的小童鞋,大神們可以繞過,錯誤之處謝謝指正
    2014-10-10
  • scala中停止循環(huán)的三種方式(推薦)

    scala中停止循環(huán)的三種方式(推薦)

    這篇文章主要介紹了scala中停止循環(huán)的三種方式,文中給大家提到了循環(huán)語句的流程圖,感興趣的朋友可以參考下
    2019-12-12
  • VSCode 格式化縮進(jìn)代碼的實現(xiàn)

    VSCode 格式化縮進(jìn)代碼的實現(xiàn)

    這篇文章主要介紹了VSCode 格式化縮進(jìn)代碼的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08

最新評論