萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> 編程語言綜合 >> Python EOL while scanning string literal問題解決方法

Python EOL while scanning string literal問題解決方法

   這篇文章主要介紹了Python EOL while scanning string literal問題解決方法,本文總結出是數據庫數據出現問題導致這個問題,需要的朋友可以參考下

  項目中有個定時任務,每天取到一些表數據傳到一個外部接口,但是最近總是有異常,今天查了下原因。

  首先本地和測試環境測試這個程序都沒問題,只有線上環境會在日志中拋出異常,猜測異常主要產生的原因是數據的異常。

  但是哪些數據有異常,由不得而知,於是增加了程序的輸出日志和數據打印,通過幾次的運行定位了發生錯誤的函數和數據記錄。

  異常是這樣的:

   代碼如下:

  EOL while scanning string literal: , line 1, pos 7

  google一下,這個異常造成的原因是字符串,引號沒有成對出現,也就是類似下面的情況

  代碼如下:

  str('1)

  Traceback (most recent call last):

  File "", line 1, in

  EOL while scanning string literal: , line 1, pos 7

  想一想程序中是沒有這樣的問題,那問題就來自數據庫中的記錄了,經過排查發現數據庫中有個字段最大長度是65k,而存入的數據大於65k,整個字符串就被截斷了。

  整個字符串不是一般的字符串,而是一個字典的字符形式,類似 str(dictA)

  dicA某個key或者是value正好被截斷 例如從{“name”:“orangleiu”} 截斷為 {"name":"orang

  所以在取出來的轉換成str類型的時候就報錯了。

  加上異常處理和字段增長長度解決了問題。

copyright © 萬盛學電腦網 all rights reserved