python常用知識(shí)梳理(必看篇)
接觸python已有一段時(shí)間了,下面針對(duì)python基礎(chǔ)知識(shí)的使用做一完整梳理:
1)避免‘\n'等特殊字符的兩種方式:
a)利用轉(zhuǎn)義字符‘\' b)利用原始字符‘r' print r'c:\now'
2)單行注釋,使用一個(gè)#,如:
#hello Python 多行注釋,使用三個(gè)單引號(hào)(或三個(gè)雙引號(hào)),如: '''hello python hello world''' 或 """hello python hello world""" 另外跨越多行的字符串。也可以使用三個(gè)單引號(hào)或三個(gè)雙引號(hào),如: '''......''' 或者 """......"""
3)字符串中嵌入雙引號(hào)等特殊符號(hào)
a)利用轉(zhuǎn)義字符‘\'
b)使用單引號(hào)括起這個(gè)字符串。print ('i l"o"ve fis.com')
4)條件分支:
if condition:
條件為真執(zhí)行的操作
else:
條件為假執(zhí)行的操作
if condition:
action
elif condition:
action
else:
action
python可以有效避免“懸掛else”(if else對(duì)應(yīng)關(guān)系出錯(cuò))
條件表達(dá)式(三元操作符)
small = x if x<y else y
如果x<y ,small=x.否則small=y
斷言assert:當(dāng)這個(gè)關(guān)鍵字后面的條件為假,程序自動(dòng)崩潰并拋出異常
assert 3>4
可以利用他置入檢查點(diǎn)
5)while條件:
條件為真執(zhí)行的操作
for 目標(biāo) in 表達(dá)式:
循環(huán)體
例:favorite='fishc'
for i in favorite:
print(i,end='')
range([start,] stop[,step=1])
生成一個(gè)從start參數(shù)的值到stop參數(shù)值的數(shù)字序列
break:終止當(dāng)前循環(huán)體。跳到外層程序
continue:終止本輪循環(huán),開始下一輪循環(huán)(if condition true)
6)and邏輯操作符可以將任意表達(dá)式連接在一起,并得到一個(gè)布爾類型值
7)引入外援:
a)random模塊 b)randint(),返回一個(gè)隨機(jī)的整數(shù) import random 或 from random import randint() secret=random.randint(1,10)
8)python數(shù)據(jù)類型
a)數(shù)值類型:整型、布爾類型、浮點(diǎn)型、e記法(1.5e10)
b)類型轉(zhuǎn)換:
int()轉(zhuǎn)換為整數(shù)
str()轉(zhuǎn)換為字符串
float()轉(zhuǎn)換為浮點(diǎn)數(shù)
c)獲取關(guān)于類型的信息:
type()函數(shù)
a=520
type(a)
isinstance()函數(shù)
a=12
isinstance(a,int) --->返回true
isinstance(a,str) -->返回false
9)Python值常用操作符
+ - * / % **(冪運(yùn)算) //(地板除法,結(jié)果偏小)
比較操作符 > < >= <=
邏輯操作符 and or not
優(yōu)先級(jí):
冪運(yùn)算**
正負(fù)號(hào) + -
算術(shù)操作符 * / //
+ -
比較操作符 < > =
邏輯擦作福 not and or
10)列表-->可以把整數(shù)、浮點(diǎn)數(shù)、字符串等打包在一起。數(shù)組卻不能
創(chuàng)建一個(gè)普通列表:
member = ['小甲魚','小布丁','黑夜']
創(chuàng)建一個(gè)混合列表:
mix=[1,'小甲魚',3.12,[1,2,3]]
創(chuàng)建空列表:
empty=[]
向列表添加元素:
append(): member.append('福祿娃')-->只能添加一個(gè)。末尾添加
extend(): member.extend(['test','test1'])-->只能以列表形式添加.末尾添加
insert(): member.insert(1,'牡丹')-->第一位插入牡丹
列表中獲取元素:使用索引index。 mix[1]
列表中刪除元素:使用remove()。 mix.remove('小甲魚')
使用del。 del mix[3]/mix
使用pop()。 mix.pop()/mix.pop(1)
列表切片:使用slice。 mix[1:4]/mix[1:]/mix[:4]
列表操作符:>,and,+,*,in/not in
列表的小伙伴:dir(list)
mix.count('小甲魚')
mix.index('小甲魚')
列表逆序:使用reverse。 mix.reverse()
列表排序:使用sort。 mix.sort()
mix.sort(func,key)
mix.sort(reverse=True)
11)元組--->不可改變的列表
和列表的主要不同點(diǎn):
a)創(chuàng)建和訪問一個(gè)元組: 大部分用()/, ;列表用[]
b)元組不可修改數(shù)值
c)更新和刪除一個(gè)元組:temp = temp[:2] + ('test3',) + temp[2:]
del temp
d)IN/NOT IN,關(guān)系操作符,邏輯操作符,乘號(hào)操作符,連接操作符
12)字符串的各種內(nèi)置方法
str1='i love fishc.com' a=str1[:6] + '插入的字符串'+str1[6:] capitalize(): str2.capitalize() casefold()--->全部小寫 str2.casefold() center(width)-->居中,不足空格填充 count(sub[,start[,end]])-->返回sub在string中出現(xiàn)的次數(shù) endswith(sub[,start[,end]])-->以sub結(jié)束? startswith(prefix[,start[,end]])-->以prefix開頭 expandtabs([tabsize=8])-->將tab鍵轉(zhuǎn)換為空格 find(sub[,start[,end]])-->sub是否在字符串中出現(xiàn) rfind(sub)... index(sub[,start[,end]])-->跟sub一樣,不過會(huì)產(chǎn)生異常 rindex(sub..)..... istitle()/isupper()/ljust(width)/lower()/strip()/title()/lower() join(sub):以字符串做分隔符,分割sub partion(sub):找到子字符串sub,把字符串分成一個(gè)3元組 replace(old,new[,count]) split(sep=none,maxsplit=-1)-->不帶參數(shù)以空格做分隔符 swapcase()-->字符串大小寫翻轉(zhuǎn) zfill(width)-->返回長(zhǎng)度為width的字符串,不夠補(bǔ)充空格
13)字符串格式化 replacement
"{0} love {1}.{2:.2f}".format("i","fishc",3.1424)
"{a} love .{c}".format(a="i",b="fishc",c="com")
"{0} love .{c}".format("i",b="fishc",c="com")
格式化符號(hào)含義:
%c:格式化字符及其ASCII碼
'%c %c %c' % (97,98,99)
%s:格式化字符串
%d:格式化整數(shù)
%o:格式化無符號(hào)八進(jìn)制數(shù)
%x:格式化無符號(hào)十六進(jìn)制數(shù) %X:...(大寫)
%f:格式化定點(diǎn)數(shù),可指定小數(shù)點(diǎn)后的精度
%e:用科學(xué)技術(shù)發(fā)格式化定點(diǎn)數(shù)===%E
%g:根據(jù)值的大小決定使用%f或%e===%G
格式化操作符輔助命令:
m.n :m是顯示的最小總寬度,n是小數(shù)位精度
- :用于左對(duì)齊
+ :在正數(shù)面前添加正號(hào)
# :在八進(jìn)制面前顯示0,在十六進(jìn)制面前顯示0x
0 :空格用0填充
字符串轉(zhuǎn)義字符
\a:發(fā)出系統(tǒng)響鈴聲
\b、\t、\n
14)序列
列表、元組和字符串的共同點(diǎn):
a)都可以通過索引
b)索引值從零開始
內(nèi)置方法:
list()-->help-->轉(zhuǎn)換為序列
list()
a=list()
list(iterable)
b='i love fishc.com'
b=list(b)
tuple([iterable])-->把一個(gè)可迭代對(duì)象轉(zhuǎn)換為元組
b=tuple(b)
str(obj)-->把obj對(duì)象轉(zhuǎn)換為字符串
len(obj)-->返回obj的長(zhǎng)度
max(序列/元組) / min(序列/元組)
sum(iterable[,start=0])-->返回序列iterable。。的總和
sorted(序列/元組)-->排序
reversed(序列/元組)-->返回一個(gè)迭代器對(duì)象
list(reversed(序列/元組))-->返回序列
enumerate(序列/元組)-->返回一個(gè)迭代器對(duì)象
list(enumerate(序列/元組))-->返回?cái)?shù)組形式列表
zip(a,b)-->合并成以元組形式的列表
list(zip(a,b))
15)函數(shù)
定義:def Myfunction():
print('this is my first function')
調(diào)用:Myfunction()
函數(shù)的參數(shù):
def Myfunction(name,age):
print(name+age+'test')
Myfunction('gncao',‘a(chǎn)ge')
函數(shù)的返回值:
return value
形參(parameter):函數(shù)定義時(shí)的參數(shù)
實(shí)參(argument):實(shí)際傳遞的參數(shù)
函數(shù)文檔:在函數(shù)中實(shí)現(xiàn)
在函數(shù)體中用 '' 或 #
查看函數(shù)文檔: a) functionname.__doc__ (四個(gè)下劃線)
b) help(functionname)
關(guān)鍵字參數(shù):避免參數(shù)出亂
def Myfunction(words,name):
......
Myfunction(words='words123',name='name123')
默認(rèn)參數(shù):
def Myfunction(name='name123',words='words123')
......
收集參數(shù):在參數(shù)前面加上*號(hào)
def test(*params):
print('參數(shù)的長(zhǎng)度是:',len(params))
print('第二個(gè)參數(shù)是:',params[1])
test(1,'小甲魚',2,4,5,6,7)
def test(*params,exp):
print('參數(shù)的長(zhǎng)度是:',len(params),exp)
print('第二個(gè)參數(shù)是:',params[1])
test(1,'小甲魚',23,4,2,5,7,exp=0)
16)函數(shù)有返回值,過程沒有返回值
17)函數(shù)變量作用域(可見性)
局部:local-->函數(shù)內(nèi)部定義的變量,局部可用 全局:global-->全局可訪問 當(dāng)在函數(shù)內(nèi)部試圖修改全局變量時(shí),則會(huì)在函數(shù)內(nèi)部新建一個(gè)跟 全局變量名相同的局部變量
18)內(nèi)嵌函數(shù)和閉包
global關(guān)鍵字:
def myfun():
global count ->>>全局變量
count=10
print(count)
內(nèi)嵌函數(shù):
def fun1():
print('fun1()正在被調(diào)用...')
def fun2():
print('fun2()正在被調(diào)用')
fun2()
只能通過fun1()訪問fun2()
閉包:在一個(gè)內(nèi)部函數(shù)中,對(duì)外部函數(shù)的變量的引用。成內(nèi)部函數(shù)為閉包
def funx(x):
def funy(y):
return x * y
return funy
調(diào)用方式:
i=funx(8)
i(5)
或
funx(4)(5)
通過關(guān)鍵字nonlocal可以使得內(nèi)部函數(shù)調(diào)用外部函數(shù)變量。
def fun1():
x=5
def fun2():
nonlocal x
x*=x
return x
return fun2()
19,遞歸:
recursion()
def fac(n):
if n==1:
return 1
else:
return n*fac(n-1)
number=int(input('請(qǐng)輸入一個(gè)整數(shù):'))
result=fac(number)
print('%d 的階乘是:%d' % (number,result))
迭代方法:
def fab(n):
n1=1
n2=1
n3=1
if n <1:
print('輸入有錯(cuò)')
return -1
while ( n-2>0 ):
n3=n2+n1
n1=n2
n2=n3
n-=1
return n3
result=fab(20)
if result != -1:
print('總共有%d對(duì)小兔子誕生:' % result)
遞歸方法:
def fab(n):
if n < 1:
print('error')
return -1
if n==1 or n==2:
return 1
else:
return fab(n-1) + fab(n-2)
result=fab(20)
print('總共有%d對(duì)兔子誕生' % result)
但是遞歸的效率比較低
20)字典(key-value)
映射/序列
例1:
dict1={'李寧':'一切皆有可能','耐克':'just do it','阿迪達(dá)斯':'impossible is nothing'}
print('李寧的口號(hào)是:',dict1['李寧'])
例2:
dict3=dict((('f',70),('i',105)))
例3:
dict4=dict(小甲魚='編程改變世界',test='test')
dict4['小甲魚']='修改小甲魚對(duì)應(yīng)的value' -->如果沒有該KEY,則會(huì)自動(dòng)添加一個(gè)KEY
字典的內(nèi)建方法:
a)
dict2['key']-->訪問字典的元素
b)
fromkeys(s[,v]) -->創(chuàng)建或查詢key
dict1.fromkeys((1,2,3))
{1: None, 2: None, 3: None}
dict1.fromkeys((1,2,3),'number')
{1: 'number', 2: 'number', 3: 'number'}
c)
keys()-->dict.keys() -->打印出dict的所有key
values()-->dict.values() -->打印出dict的所有value
items()-->dict.items() -->打印出dict所有(key,value)
get()--> dict.get(key) -->打印key對(duì)應(yīng)的value
dict.get(key,'text')-->打印key對(duì)應(yīng)的value,如果不存在,則打印text
in操作符 --> key in dict2
clear() -->dict.clear() -->清空dict的數(shù)據(jù)
copy() -->b=a.copy() -->拷貝字典
id(a)-->查看id
pop(key) --> dict.pop(key) -->彈出key
popitem() -->dict.popitem() -->隨機(jī)彈出key
setdefault() -->dict.setdefault(key) -->新建key
update() -->dict.update(dict) -->更新字典
21)集合 --->唯一性
num={1,2,3,4,5}
set()-->set1=set(列表/元組/字符串)
不支持索引
訪問集合中的值:
使用for循環(huán)一一查找
使用IN 或者 NOT IN
add()-->set1.add(value)
remove()-->set1.remove(value)
不可變集合:
num3=frozenset(元組/列表)
22)文件
輸入-->處理-->輸出
內(nèi)存--->磁盤
open()打開文件:
open('filename/path',mode='rwxabt+U')
文件對(duì)象方法:
f.close() -->關(guān)閉文件
f.read(size=-1) -->從文件讀取size個(gè)字符
f.readline() -->以寫入模式打開,如果文件存在,則在末尾添加
f.write(str) -->將str寫入文件
f.writelines(seq) ->向文件寫入seq序列。seq應(yīng)該是一個(gè)返回字符串序列
f.tell() -->返回當(dāng)前的位置。書簽
f.seek(offset,from) -->在文件中移動(dòng)文件指針,從from偏移offset字節(jié)
for each in f: ---->瀏覽整個(gè)文件
print(each)
23)文件系統(tǒng)
模塊:打包的文件系統(tǒng) os模塊: 常用方法: os.getcwd():返回工作目錄 os.chdir(path):改變工作目錄 os.listdir(path=''):列出文件目錄 os.mkdir(path):創(chuàng)建目錄 os.makedirs(path):創(chuàng)建遞歸目錄 os.remove(path):刪除文件 os.removedirs(path):遞歸刪除 os.rename(old,new):文件重命名 os.system(command):運(yùn)行系統(tǒng)的shell命令 os.curdir:指代當(dāng)前目錄.等價(jià)于‘。' os.pardir:指代上一級(jí)目錄 os.sep:輸出操作系統(tǒng)的路徑分隔符 os.linesep:當(dāng)前平臺(tái)使用的行終止符 os.name:指出當(dāng)前使用的操作系統(tǒng)
24)永久存儲(chǔ)
存放:pickling
讀取:unpickling
首先要導(dǎo)入模塊pickle
import pickle
>>> my_list=[1,2,3,'test',[23,43]]
>>> pickle_file=open('my_list.pkl','wb') --》打開一個(gè)pickle文件
>>> pickle.dump(my_list,pickle_file) --》把my_list導(dǎo)入到pickle_file
>>>pickle_file.close()
>>> pickle_file=open('my_list.pkl','wb')
>>> my_list2=pickle.load(pickle_file) -->把pickle_file導(dǎo)入到my_list2
25)異常處理
常見標(biāo)準(zhǔn)異常:
AssertionErron/AttributeError/EOFError/IndexError/KeyError
/NameError/OSError/OverflowError/SyntaxError/TypeError/ZeroDivisionError
捕獲異常:
try:
檢測(cè)范圍
except Exception[as reason]:
出現(xiàn)異常后的處理代碼 print('代碼')
except Exception[as reason];
出現(xiàn)異常后的處理代碼 print('daimai'+ str(reason))
except (Error1,Error2):
處理異常的代碼
try:
檢測(cè)范圍
except Exception[as reason]:
處理異常的代碼
finally:
無論如何都會(huì)處理的代碼
raise語句拋出異常
raise Exception('指示代碼')
26)豐富的else語句和簡(jiǎn)潔的with語句
else配合其他語句產(chǎn)生更多的功能
with語句:縮小工作量:
沒有使用with前:
try:
f=open('data.txt','r')
for each in f:
print(each)
except OSError as reason:
print('出錯(cuò)啦:'+str(reason))
finally:
f.close()
使用with后:
try:
with open('data.txt','w') as f:
for each in f:
print(each)
except OSError as reason:
print('出錯(cuò)啦:'+str(reason))
導(dǎo)入模塊三種方式:
a)import easygui
easygui.msgbox('test')
b)from easygui import *
msgbox('test')
c)import easygui as g
g.msgbox('test')
建議不要再IDLE上運(yùn)行EASYGUI
關(guān)鍵詞class
class Turtle:
#屬性
color='green'
weight=10
#方法:
def climb(self)
print('climb tree')
調(diào)用:
tt=Turtle() -->創(chuàng)建對(duì)象
tt.climb() -->調(diào)用方法
oo=面向?qū)ο?
oo的特征:
1,封裝
2,繼承
class mylist(list):
pass --->表示只繼承父類,不做其他任何改動(dòng)
list2=mylist()
3,多態(tài)
self-->相當(dāng)于c++的this指針
>>> class ball:
def setname(self,name):
self.name=name
def kick(self):
print('i am %s,who kicked me????' % self.name)
a=ball()
a.setname('test')
4,_init_(self) --->構(gòu)造方法
>>> class ball:
def __init__(self,name):
self.name=name
def kick(self):
print('i am %s,who kicked me????' % self.name)
b=ball('test')
5,公有和私有
類屬性和方法默認(rèn)都是公有的
name mangling --->名字改編,名字重整
私有變量:在變量名或函數(shù)名前加上'__'雙下劃線
訪問私有變量方法:
1,在類內(nèi)定義方法,間接訪問私有變量
2,._類名__變量名
6,繼承
class derivedclassname(basename):
....
如果子類中出現(xiàn)和父類相同的方法,則覆蓋掉父類的方法
不想覆蓋掉父類的方法:
1,調(diào)用未綁定的父類方法
def __init__(self):
fish.__init__(self) ----》先調(diào)用父類同名的方法
self.hungry=True
2,使用super函數(shù)
def __init__(self):
super().__init__()
self.hungry=True
7,多重繼承
class derivedclass(base1,base2,base3):
......
8,拾遺
Mix-in編程機(jī)制
類,類對(duì)象,實(shí)例對(duì)象,實(shí)例屬性(static)
如果屬性的名字和方法的名字相同,則屬性會(huì)覆蓋掉方法
綁定:
class bb:
def printbb():
print('no zuo no die')
b1=bb()
b1.printbb() ---->會(huì)出錯(cuò)誤
9,一些相關(guān)的BIF:
issubclass(class,classinfo)
1,一個(gè)類被認(rèn)為是自己的子類
2,classinfo可以是類對(duì)象組成的元祖,只要class與其中任何一個(gè)候選類的子類,則返回TRUE
isinstance(object,classinfo)
檢查對(duì)象是否屬于classinfo類
1,如果第一個(gè)參數(shù)不是對(duì)象,則永遠(yuǎn)返回fasle
2,如果第二個(gè)不是類,則會(huì)拋出typeerror的異常
hasattr(object,name) -->測(cè)定object中是否有'name‘屬性
hasattr(c1,'x')
getattr(object,name[,default]) -->如果有屬性返回1,否則返回default
setattr(object,name,value) -->給object中的name屬性賦值vlalue
delattr(object,name) -->刪除object中的name屬性
property(fget=none,fset=none,fdel=none,doc=none)設(shè)置屬性,設(shè)置定義好的屬性
獲取屬性的方法,設(shè)置屬性的方法,刪除屬性的方法
class c:
def __init__(self,size=10):
self.size=size
def getsize(self):
return self.size
def setsize(self,value):
self.size=value
def delsize(self):
del self.size
x=property(getsize,setsize,delsize)
c1=c()
c1.x / c1.x=19 /c1.size
29)魔法方法(構(gòu)造和析構(gòu))
特點(diǎn):
1,魔法方法總是被雙下劃線包圍,例如__init__
2,魔法方法是面向?qū)ο髉ython的一切
3,魔法方法的魔力體現(xiàn)在他們總能夠在適當(dāng)?shù)臅r(shí)候被自動(dòng)調(diào)用
構(gòu)造方法:
__init__(self[,...]) -->返回值一定是NONE
用在實(shí)例初始化
__new__(cls[,...]) --->第一個(gè)初始化的方法
當(dāng)繼承一個(gè)不可修改屬性的類時(shí),則調(diào)用此方法修改屬性
class capstr(str):
def __new__(cls,string):
string=string.upper()
return str.__new__(cls,string)
析構(gòu)方法:
__del__(self) 當(dāng)數(shù)據(jù)不適用時(shí),調(diào)用此方法
只有在調(diào)用了該對(duì)象的所有實(shí)例都消失時(shí)才會(huì)產(chǎn)生此方法
30)魔法方法:算術(shù)運(yùn)算
__add__(self,other):定義加法的行為'+'
例子:
>>> class new_int(int):
def __add__(self,other):
return int.__sub__(self,other)
def __sub__(self,other):
return int.__add__(self,other)
>>> a=new_int(3)
>>> b=new_int(8)
>>> a+b ---->此時(shí)a是self,b是other
-5
__sub__(sub,other):減法
__mul__(sub,other):乘法
truediv/floordiv/mod/divmod/pow/lshift/rshift/and/xor/or
divmod(a,b)返回的值是一個(gè)元祖:(a//b,a%b)
31)網(wǎng)絡(luò)socket
socket提供較為底層的網(wǎng)絡(luò)連接及數(shù)據(jù)傳輸功能
tcp socket/udp socket/unix socket
整個(gè)通信過程三步走:
a)客戶端連接服務(wù)器:
導(dǎo)入模塊:
import socket
創(chuàng)建tcp類型的socket:
c=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
建立到指定ip地址、端口的tcp連接
c.connect(('211.121.12.43',80))
在系統(tǒng)上使用netstat命令查看新建的連接:
關(guān)閉連接:
c.close()
b)服務(wù)器端監(jiān)聽:
import socket
s=socket.socket(socket.AF_INET,socket.sock.SOCK_STREAM)
s.bind(('127.0.0.1',80))
s.listen(1)
while True:
cs,ca=s.accept() -->創(chuàng)建socket和客戶端通信
cs.sendall('replay')
cs.close()
c)客戶端收發(fā)數(shù)據(jù):
import socket
c=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
c.connect(('211.121.12.43',80))
向服務(wù)端發(fā)送‘hello'
c.send('hello')
讀取服務(wù)端回復(fù)數(shù)據(jù):
c.recv(1024)
c.close()
32)HTTP庫(kù)實(shí)現(xiàn)HTTP協(xié)議
導(dǎo)入httplib模塊:
import httplib
創(chuàng)建http實(shí)例,指定連接主機(jī)名和端口:
http=httplib.HTTPConnection('itercast.com',80)
指定要獲取的URI:
http.request('GET','/ask') -->get方法獲取指定數(shù)據(jù),ask表示要訪問的頁面
輸出返回的網(wǎng)頁body內(nèi)容:
print http.getresponse().read()
關(guān)閉連接:
http.close()
更簡(jiǎn)單的urllib庫(kù):
導(dǎo)入urllib模塊
import urllib
創(chuàng)建一個(gè)opener的實(shí)例
opener=urllib.build_opener()
打開指定的url
f=opener.open('http://www.baidu.com/ask')
讀取返回內(nèi)容
f.read()
33)python連接mysql的模塊
import MySQLdb
conn=MySQLdb.connect(user='root',passwd='',host='127.0.0.1') --->連接mysql,默認(rèn)是localhost
創(chuàng)建游標(biāo),通過游標(biāo)發(fā)送sql指令
cur=conn.cursor()
conn.select_db('database-name') --》連接數(shù)據(jù)庫(kù),本例用week
cur.execute('insert into userinfo(name,age) value('milo',20)') --》執(zhí)行sql語句。insert
簡(jiǎn)單化操作方式:
sqli='insert into userinfo(name,age,gender) value(%s,%s,%s)'
cur.execute(sqli,('a',37,'male'))
cur.executemany(sqli,[('test',34,'male'),('test2',36,'female')])
cur.execute('delete from userinfo where id=20') -->刪除數(shù)據(jù)
cur.execute('select * from userinfo') -->查詢數(shù)據(jù),但是不能直接顯示,使用以下方法可以查看
cur.fetchone()-->在python上顯示一行數(shù)據(jù)
cur.scroll(0,'absolute')-->移動(dòng)指標(biāo),此為絕對(duì)方式
cur.fetchmany(15)-->在python上顯示15條數(shù)據(jù).需要輸入數(shù)據(jù)。必須先查詢
cur.fetchmany(cur.execute('select * from userinfo')) -->通過一條命令顯示數(shù)據(jù)
cur.close() -->關(guān)閉游標(biāo)的連接
conn.close() --->關(guān)閉數(shù)據(jù)庫(kù)連接
以上這篇python常用知識(shí)梳理(必看篇)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
28)類和對(duì)象
27)圖形用戶界面編程:EasyGui
相關(guān)文章
使用Python獲取字典鍵對(duì)應(yīng)值的兩種方法
對(duì)于字典通過鍵獲得值非常簡(jiǎn)單,但通過值獲得鍵則需繞些彎子,下面這篇文章主要給大家介紹了關(guān)于如何使用Python獲取字典鍵對(duì)應(yīng)值的相關(guān)資料,需要的朋友可以參考下2022-04-04
Python進(jìn)階教程之創(chuàng)建本地PyPI倉(cāng)庫(kù)
pypi是一個(gè)python包的倉(cāng)庫(kù),里面有很多別人寫好的python庫(kù),你可以通過easy_install或者pip進(jìn)行安裝,下面這篇文章主要給大家介紹了關(guān)于Python進(jìn)階教程之創(chuàng)建本地PyPI倉(cāng)庫(kù)的相關(guān)資料,需要的朋友可以參考下2021-10-10
python標(biāo)識(shí)符命名規(guī)范原理解析
這篇文章主要介紹了python標(biāo)識(shí)符命名規(guī)范原理解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-01-01
python多線程調(diào)用exit無法退出的解決方法
今天小編就為大家分享一篇python多線程調(diào)用exit無法退出的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-02-02

