2017-07-06 69 views
0

我想獲取本網站的日期,但我可以得到它,但它會向列中添加錯誤。 打印:http://prntscr.com/fsav5h向表中添加數字時出錯

代碼:

page = urllib2.urlopen('https://www.meetup.com/find/events/career-business/?allMeetups=false&radius=50&userFreeform=London&mcId=c1012717&change=yes') 
soup = BeautifulSoup(page, 'html.parser') 

events = soup.find('div', class_='unit size5of7 ') 

A = [] 

try: 
    conn = psycopg2.connect("dbname='meetup' user='postgres' host='localhost' password='root'") 
except: 
    print 'Unable to connect to the database.' 

cur = conn.cursor() 

for event in events.findAll('ul', class_="searchResults resetList clearfix"): 
    date = event.findAll('li', class_="date-indicator") 
    if len(date) != 0: 
     A.append(date[0].find(text = True)) 
     cur.execute("""UPDATE events SET event_date = %s WHERE event_date = '' """ % tuple(A)) 
     conn.commit() 
     del A[:] 

回答

0

試試這個

cur.execute("""UPDATE events SET event_date = '%s' WHERE event_date = '' """, (tuple(A))) 
+0

它繼續發生:C –

+0

驗證日期格式在Postgres的接受。嘗試在Postgres中直接更新。 –

+0

Postgres接受它。我還刪除了WHERE event_date ='',因爲它返回了0行受到影響。 –