這篇文章主要介紹了Python EOL while scanning string literal問題解決方法,本文總結出是數據庫數據出現問題導致這個問題,需要的朋友可以參考下
項目中有個定時任務,每天取到一些表數據傳到一個外部接口,但是最近總是有異常,今天查了下原因。
首先本地和測試環境測試這個程序都沒問題,只有線上環境會在日志中拋出異常,猜測異常主要產生的原因是數據的異常。
但是哪些數據有異常,由不得而知,於是增加了程序的輸出日志和數據打印,通過幾次的運行定位了發生錯誤的函數和數據記錄。
異常是這樣的:
代碼如下:
EOL while scanning string literal:
google一下,這個異常造成的原因是字符串,引號沒有成對出現,也就是類似下面的情況
代碼如下:
str('1)
Traceback (most recent call last):
File "
EOL while scanning string literal:
想一想程序中是沒有這樣的問題,那問題就來自數據庫中的記錄了,經過排查發現數據庫中有個字段最大長度是65k,而存入的數據大於65k,整個字符串就被截斷了。
整個字符串不是一般的字符串,而是一個字典的字符形式,類似 str(dictA)
dicA某個key或者是value正好被截斷 例如從{“name”:“orangleiu”} 截斷為 {"name":"orang
所以在取出來的轉換成str類型的時候就報錯了。
加上異常處理和字段增長長度解決了問題。