[英]%d by python and addition ValueError: unsupported format character 'O' (0x4f) at index 2
[英]unsupported format character 'O' (0x4f) at index 79
使用Psycopg2模塊執行查詢時出現以下錯誤。 我已經在PgAdmin 4中執行了相同的查詢,並且運行良好,並且給了我結果 。當我通過Python執行該錯誤時會發生錯誤。
誰能建議我如何解決這個問題?
下面是代碼:
for new_ticket in zenpy_client.search(type='ticket', status='open',requester='je.rr.y@gmail.com'):
#new_ticket.assignee = modified_user
#print(new_ticket.requester.email)
psql_command=""" WITH CTE AS (select cast(origin as text) as origin, MAX(case when name like '%OUT%' THEN name else ''end) as out_ref
, MAX(case when name like '%PICK%' THEN name else ''end) as pick_ref
, MAX(case when name like '%PICK%' THEN state else ''end) as pick_state
, MAX(case when name like '%OUT%' THEN state else ''end) as out_state
from dl_odoo.stock_picking
GROUP BY origin)
select o.customer_email,o.order_number,o.order_state_1,o.order_state_2,o.order_subtotal_net_after_discount as revenue
,created_at_order,c.out_ref as reference,o.payment_method,c.pick_ref,c.pick_state,c.out_ref,c.out_state
from ol.orders o
LEFT JOIN CTE c ON c.origin=o.order_number
where
customer_email='%s' order by o.created_at_order desc limit 3
;"""
try:
s=''
print(new_ticket.requester.email)
print(psql_command)
try:
psql_cursor.execute(psql_command %new_ticket.requester.email)
except (Exception, psycopg2.Error) as error:
print ("ssss")
print (error)
您需要轉義字符串中的百分號。 Python將它們解釋為好像是類似於printf的格式說明符。 用%%替換每個%,它應該可以工作。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.