當前位置:首頁 » 編程語言 » python插入

python插入

發布時間: 2022-07-14 19:55:08

Ⅰ 如何使用python連接資料庫,插入並查詢數據

你可以訪問Python資料庫介面及API查看詳細的支持資料庫列表。不同的資料庫你需要下載不同的DB API模塊,例如你需要訪問Oracle資料庫和Mysql數據,你需要下載Oracle和MySQL資料庫模塊。
DB-API 是一個規范. 它定義了一系列必須的對象和資料庫存取方式, 以便為各種各樣的底層資料庫系統和多種多樣的資料庫介面程序提供一致的訪問介面 。
Python的DB-API,為大多數的資料庫實現了介面,使用它連接各資料庫後,就可以用相同的方式操作各資料庫。
Python DB-API使用流程:

引入 API 模塊。
獲取與資料庫的連接。
執行SQL語句和存儲過程。
關閉資料庫連接。

什麼是MySQLdb?

MySQLdb 是用於Python鏈接Mysql資料庫的介面,它實現了 Python 資料庫 API 規范 V2.0,基於 MySQL C API 上建立的。

如何安裝MySQLdb?

為了用DB-API編寫MySQL腳本,必須確保已經安裝了MySQL。復制以下代碼,並執行:
#!/usr/bin/python
# -*- coding: UTF-8 -*-

import MySQLdb

如果執行後的輸出結果如下所示,意味著你沒有安裝 MySQLdb 模塊:
Traceback (most recent call last):
File "test.py", line 3, in <mole>
import MySQLdb
ImportError: No mole named MySQLdb

安裝MySQLdb,請訪問 ,(Linux平台可以訪問:)從這里可選擇適合您的平台的安裝包,分為預編譯的二進制文件和源代碼安裝包。
如果您選擇二進制文件發行版本的話,安裝過程基本安裝提示即可完成。如果從源代碼進行安裝的話,則需要切換到MySQLdb發行版本的頂級目錄,並鍵入下列命令:
$ gunzip MySQL-python-1.2.2.tar.gz
$ tar -xvf MySQL-python-1.2.2.tar
$ cd MySQL-python-1.2.2
$ python setup.py build
$ python setup.py install

注意:請確保您有root許可權來安裝上述模塊。

資料庫連接

連接資料庫前,請先確認以下事項:

您已經創建了資料庫 TESTDB.
在TESTDB資料庫中您已經創建了表 EMPLOYEE
EMPLOYEE表欄位為 FIRST_NAME, LAST_NAME, AGE, SEX 和 INCOME。
連接資料庫TESTDB使用的用戶名為 "testuser" ,密碼為 "test123",你可以可以自己設定或者直接使用root用戶名及其密碼,Mysql資料庫用戶授權請使用Grant命令。
在你的機子上已經安裝了 Python MySQLdb 模塊。
如果您對sql語句不熟悉,可以訪問我們的 SQL基礎教程

實例:

以下實例鏈接Mysql的TESTDB資料庫:
#!/usr/bin/python
# -*- coding: UTF-8 -*-

import MySQLdb

# 打開資料庫連接
db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )

# 使用cursor()方法獲取操作游標
cursor = db.cursor()

# 使用execute方法執行SQL語句
cursor.execute("SELECT VERSION()")

# 使用 fetchone() 方法獲取一條資料庫。
data = cursor.fetchone()

print "Database version : %s " % data

# 關閉資料庫連接
db.close()

執行以上腳本輸出結果如下:
Database version : 5.0.45

創建資料庫表

如果資料庫連接存在我們可以使用execute()方法來為資料庫創建表,如下所示創建表EMPLOYEE:
#!/usr/bin/python
# -*- coding: UTF-8 -*-

import MySQLdb

# 打開資料庫連接
db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )

# 使用cursor()方法獲取操作游標
cursor = db.cursor()

# 如果數據表已經存在使用 execute() 方法刪除表。
cursor.execute("DROP TABLE IF EXISTS EMPLOYEE")

# 創建數據表SQL語句
sql = """CREATE TABLE EMPLOYEE (
FIRST_NAME CHAR(20) NOT NULL,
LAST_NAME CHAR(20),
AGE INT,
SEX CHAR(1),
INCOME FLOAT )"""

cursor.execute(sql)

# 關閉資料庫連接
db.close()

資料庫插入操作

以下實例使用執行 SQL INSERT 語句向表 EMPLOYEE 插入記錄:
#!/usr/bin/python
# -*- coding: UTF-8 -*-

import MySQLdb

# 打開資料庫連接
db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )

# 使用cursor()方法獲取操作游標
cursor = db.cursor()

# SQL 插入語句
sql = """INSERT INTO EMPLOYEE(FIRST_NAME,
LAST_NAME, AGE, SEX, INCOME)
VALUES ('Mac', 'Mohan', 20, 'M', 2000)"""
try:
# 執行sql語句
cursor.execute(sql)
# 提交到資料庫執行
db.commit()
except:
# Rollback in case there is any error
db.rollback()

# 關閉資料庫連接
db.close()

以上例子也可以寫成如下形式:
#!/usr/bin/python
# -*- coding: UTF-8 -*-

import MySQLdb

# 打開資料庫連接
db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )

# 使用cursor()方法獲取操作游標
cursor = db.cursor()

# SQL 插入語句
sql = "INSERT INTO EMPLOYEE(FIRST_NAME, \
LAST_NAME, AGE, SEX, INCOME) \
VALUES ('%s', '%s', '%d', '%c', '%d' )" % \
('Mac', 'Mohan', 20, 'M', 2000)
try:
# 執行sql語句
cursor.execute(sql)
# 提交到資料庫執行
db.commit()
except:
# 發生錯誤時回滾
db.rollback()

# 關閉資料庫連接
db.close()

實例:

以下代碼使用變數向SQL語句中傳遞參數:
..................................
user_id = "test123"
password = "password"

con.execute('insert into Login values("%s", "%s")' % \
(user_id, password))
..................................

資料庫查詢操作

Python查詢Mysql使用 fetchone() 方法獲取單條數據, 使用fetchall() 方法獲取多條數據。

fetchone(): 該方法獲取下一個查詢結果集。結果集是一個對象
fetchall():接收全部的返回結果行.
rowcount: 這是一個只讀屬性,並返回執行execute()方法後影響的行數。

實例:

查詢EMPLOYEE表中salary(工資)欄位大於1000的所有數據:
#!/usr/bin/python
# -*- coding: UTF-8 -*-

import MySQLdb

# 打開資料庫連接
db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )

# 使用cursor()方法獲取操作游標
cursor = db.cursor()

# SQL 查詢語句
sql = "SELECT * FROM EMPLOYEE \
WHERE INCOME > '%d'" % (1000)
try:
# 執行SQL語句
cursor.execute(sql)
# 獲取所有記錄列表
results = cursor.fetchall()
for row in results:
fname = row[0]
lname = row[1]
age = row[2]
sex = row[3]
income = row[4]
# 列印結果
print "fname=%s,lname=%s,age=%d,sex=%s,income=%d" % \
(fname, lname, age, sex, income )
except:
print "Error: unable to fecth data"

# 關閉資料庫連接
db.close()

以上腳本執行結果如下:
fname=Mac, lname=Mohan, age=20, sex=M, income=2000

資料庫更新操作

更新操作用於更新數據表的的數據,以下實例將 TESTDB表中的 SEX 欄位全部修改為 'M',AGE 欄位遞增1:
#!/usr/bin/python
# -*- coding: UTF-8 -*-

import MySQLdb

# 打開資料庫連接
db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )

# 使用cursor()方法獲取操作游標
cursor = db.cursor()

# SQL 更新語句
sql = "UPDATE EMPLOYEE SET AGE = AGE + 1
WHERE SEX = '%c'" % ('M')
try:
# 執行SQL語句
cursor.execute(sql)
# 提交到資料庫執行
db.commit()
except:
# 發生錯誤時回滾
db.rollback()

# 關閉資料庫連接
db.close()

刪除操作

刪除操作用於刪除數據表中的數據,以下實例演示了刪除數據表 EMPLOYEE 中 AGE 大於 20 的所有數據:
#!/usr/bin/python
# -*- coding: UTF-8 -*-

import MySQLdb

# 打開資料庫連接
db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )

# 使用cursor()方法獲取操作游標
cursor = db.cursor()

# SQL 刪除語句
sql = "DELETE FROM EMPLOYEE WHERE AGE > '%d'" % (20)
try:
# 執行SQL語句
cursor.execute(sql)
# 提交修改
db.commit()
except:
# 發生錯誤時回滾
db.rollback()

# 關閉連接
db.close()

執行事務

事務機制可以確保數據一致性。

事務應該具有4個屬性:原子性、一致性、隔離性、持久性。這四個屬性通常稱為ACID特性。

原子性(atomicity)。一個事務是一個不可分割的工作單位,事務中包括的諸操作要麼都做,要麼都不做。
一致性(consistency)。事務必須是使資料庫從一個一致性狀態變到另一個一致性狀態。一致性與原子性是密切相關的。
隔離性(isolation)。一個事務的執行不能被其他事務干擾。即一個事務內部的操作及使用的數據對並發的其他事務是隔離的,並發執行的各個事務之間不能互相干擾。
持久性(rability)。持續性也稱永久性(permanence),指一個事務一旦提交,它對資料庫中數據的改變就應該是永久性的。接下來的其他操作或故障不應該對其有任何影響。

Python DB API 2.0 的事務提供了兩個方法 commit 或 rollback。

Ⅱ python怎麼在word表中插圖片

# -*- coding: UTF8 -*-from docx import Documentfrom docx.shared import Pt doc = Document() # 文件存儲路徑path = "C:\\Users\\Administrator\\Desktop\\word文檔\\" # 讀取文檔# doc = Document(path + "hello.docx") # 添加圖片,後面的參數設置圖片尺寸,可以選填doc.add_picture(path + 'cat.jpg', width=Pt(300))

Ⅲ Python如何一次插入多行數據

你學習過資料庫嗎?

方法是多種的,這里以mysql為例!

1、用phpmyadmin,登錄進去,然後查看你的資料庫,插入數值,很快你就會錄入完成了

2、用python操作資料庫,這里也是mysql, 首先要安裝pymsql模塊,這樣你就可以讀取資料庫了

連接資料庫,查看,插入,確認完成

具體

conn=pymysql.Connect(user=username,passwd=password,database=database,charset=charset)
cur=conn.cursor()
cur.execute('select*fromtable')
cur.executemany(......)
conn.commit()
##username,password,dtabase,都是你自己資料庫的設置,命令自己去學下,5分鍾就會,特別是executemany可以批量執行插入,其實execute也可以

Ⅳ python 插入行

加了一行,i要加2,不然空行會參加對比

Ⅳ python中列表的這種插入怎麼理解

LZ,列表是python數據結構之一,而切片處理是列表常見的數據處理方法,,,
列表中的每個元素都分配一個數字(索引),第一個是0,第二個是1,元素倒數時則以1開始,,,
L[2]為讀取第三個元素: L[2] = 2
L[2:]為從第三個元素開始截取列表: L[2:] = [2,3,4]
L[:2]為截取第三個元素之前的列表: L[:2] = [0,1]
L[2:2]=[8,9]即:以第三個元素前開始,第三個之前結束,,,就是說在第三個元素之前插入[8,9]: L=[0, 1, 8, 9, 2, 3, 4]
另外插入賦值時必須用列表操作符「[ ]」,,
Python的靈活多變,有時候需要多動手操作才能理解囖,,科科,,,

Ⅵ python怎麼在字元串中插入字元

1、添加字元實現

添加字元或字元串

如果想在字元串 土堆 後面或者前面添加 碎念 字元串。
可以使用 + 號實現字元串的連接,或者使用方法 .join() 來連接字元串。
.join() 方法

官方是這樣介紹的:
S.join(iterable) -> str Return a string which is the concatenation of the strings in the iterable. The separator between elements is S.
.join() 方法中傳遞的參數需要是可迭代的,另外,是使用S作為可迭代參數的分割。
通過以上幾點,我們可以這樣理解:
a.join(b) ,比如 b=123456,是可以迭代的。這個方法的作用就是把a插入到b中每個字元中。1a2a3a4a5a6就是輸出。
''.join([a, b]) 是比較常見的用法。 '' 是空字元,意味著在a, b之間加入空字元,也就是將a, b進行了連接。
實現添加
a = '撒旦士大試試夫'
b = '土堆試夫'
print(a + b)print(''.join([a, b]))
2、插入字元實現

首先將字元串轉換為列表,然後使用列表的 .insert() 方法來插入字元。
.insert() 用法

L.insert(index, object) -- insert object before index

注意: .insert() 方法不返回參數,直接在對 L 進行修改。
將對象插入到指定位置的前面。比如 ['a', 'b'].insert(1, 'c') ,那麼最後的輸出就是`['a', 'c', 'b']。
這個方法是屬於列表的方法。
實現插入

a = '撒旦士大試試夫'
b = '土堆'str_list = list(a)str_list.insert(4, b)a_b = ''.join(str_list)

Ⅶ python怎麼用insert函數插入多個值

a=[1,2,3,9,10]
b=[4,5,6,7,8]
c=a[:3]+b+a[3:]
print(c)
#[1,2,3,4,5,6,7,8,9,10]


#Solution2:uselist.insert(index,element)
a=[1,2,3,9,10]
b=[4,5,6,7,8]
index=3
foriinb[::-1]:
a.insert(index,i)
print(a)
#[1,2,3,4,5,6,7,8,9,10]

Ⅷ python列表中依次插入不同元素

可以使用append()方法,或者extend()方法,還可使用insert()方法。insert()主要用來插入元素,當向列表末尾添加元素時,還是應該使用append()方法。
通過使用「+」運算符可以將多個序列進行連接,列表也不例外。
使用「+」運算符,確實可以像列表中添加元素。但是這種方式的執行效率並不高,大家可以使用列表提供的append()方法。Pythonappend()方法添加元素,append()方法用於在列表的末尾追加元素。

Ⅸ 急求大神指教:怎樣用python在指定文件中的指定行插入一句話呢

1、打開pycharm開發工具,在python項目中,定義列表變數b1並賦值。

熱點內容
php安裝mbstring 發布:2024-05-17 22:09:56 瀏覽:470
單向板中配置哪些鋼筋 發布:2024-05-17 22:09:16 瀏覽:797
winftp下載 發布:2024-05-17 21:51:33 瀏覽:692
壓縮板包裝 發布:2024-05-17 21:44:59 瀏覽:264
安卓大屏怎麼安裝手機卡 發布:2024-05-17 21:39:09 瀏覽:753
xml導入sql 發布:2024-05-17 21:34:13 瀏覽:526
蘋果x怎麼清除緩存 發布:2024-05-17 21:34:00 瀏覽:786
我的世界紅石怎麼卡伺服器 發布:2024-05-17 21:03:53 瀏覽:44
吃麵包解壓神器 發布:2024-05-17 20:50:32 瀏覽:336
木料方演算法 發布:2024-05-17 20:44:18 瀏覽:763