第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

如何使用 SQLite3 和 Python 更新 SQLite 表中的行

如何使用 SQLite3 和 Python 更新 SQLite 表中的行

桃花長(zhǎng)相依 2023-08-03 17:23:39
我是 python 新手,不太了解 sql 的東西。目前是團(tuán)隊(duì)樹屋的第六周,所以如果這些是菜鳥問題,請(qǐng)?jiān)谶@里與我交流。目標(biāo)導(dǎo)入包含 stock_tickers 和其他 5 列數(shù)據(jù)的 CSV將 CSV 轉(zhuǎn)換為 pandas 數(shù)據(jù)框?qū)?shù)據(jù)框?qū)霐?shù)據(jù)庫。如果已經(jīng)有唯一的stock_ticker,則不添加新行,而是接下來檢查其他5列中的數(shù)據(jù)是否不同。如果是的話就更新它?,F(xiàn)在我可以執(zhí)行步驟 #1 和 #2 以及步驟 #3 的一半。在此處的幫助下,能夠使循環(huán)工作正常工作。如果 csv 中有新的 stock_ticker 行,它會(huì)將其添加到數(shù)據(jù)庫中。如果現(xiàn)有 stock_ticker 的數(shù)據(jù)發(fā)生變化,它不會(huì)進(jìn)行任何更新。for i in range(len(df)):    try:        df[df.index == i].to_sql(name='stocks', con=conn, if_exists='append', index=False)        conn.commit()    except sqlite3.IntegrityError:        pass當(dāng)前代碼如下所示import pandas as pdfrom pandas import DataFramefrom pandas import ExcelWriterimport csvimport sqlite3### IMPORT CSV ###stock_csv_file = pd.read_csv (r'C:\Users\home\Desktop\code_projects\FIRE_Dashboard\db\alpha_vantage_active_stocks.csv')### CHANGING INDEX NAMES FROM CSV TO TABLE NAMES ###df = pd.DataFrame(stock_csv_file)df = df.rename(columns = {"symbol":"stock_ticker", "name":"stock_name", "exchange":"stock_exchange", "ipoDate":"stock_ipoDate", "delistingDate":"stock_delistingDate", "status":"stock_status"})### UPDATING DATABSE WITH SQLITE3###conn = sqlite3.connect('stockmarket.db')c = conn.cursor()insert_statement = """INSERT INTO stocks (stock_ticker,                    stock_name,                    stock_exchange,                    stock_ipoDate,                    stock_delistingDate,                    stock_status                    )VALUES (?, ?, ?, ?, ?, ?)ON CONFLICT (stock_ticker) DO UPDATE    SET (stock_status)"""    for i in range(len(df)):    values = tuple(df.iloc[i])    c.execute(insert_statement, values)我收到的錯(cuò)誤Traceback (most recent call last):  File "update_stock_tickers.py", line 71, in <module>    c.execute(insert_statement, values)sqlite3.OperationalError: incomplete input
查看完整描述

1 回答

?
茅侃侃

TA貢獻(xiàn)1842條經(jīng)驗(yàn) 獲得超22個(gè)贊

這是ON CONFLICT您的查詢的子句:


ON CONFLICT (stock_ticker) DO UPDATE

    SET (stock_status)

這不是有效的 SQLite 語法。stock_status如果您想在另一行已存在且具有相同的行時(shí)進(jìn)行更新stock_ticker,您可以使用偽表,EXCLUDED如下所示:


INSERT INTO stocks (stock_ticker,

                    stock_name,

                    stock_exchange,

                    stock_ipoDate,

                    stock_delistingDate,

                    stock_status

                    )

VALUES (?, ?, ?, ?, ?, ?)

ON CONFLICT (stock_ticker) DO UPDATE

    SET stock_status = EXCLUDED.status


查看完整回答
反對(duì) 回復(fù) 2023-08-03
  • 1 回答
  • 0 關(guān)注
  • 234 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)