Python基礎知識匯總

來源:互聯網
上載者:User

標籤:count   注意事項   布爾值   else   for 迴圈   字元編碼   pen   erro   oct   

Python a.py     直接調用Python解譯器執行檔案

chomd +x a.py   ./a.py    #修改a.py檔案的屬性,為可執行,在用  ./  執行a.py 檔案

2、簡述位、位元組的關係

1bytes=8bit  ,2**8=256,可以代表256中變化,

 

3、簡述 ascii、unicode、utf-8、gbk 的關係

ascii 是最早美國用的標準資訊交換碼,把所有的字母的大小寫,各種符號用 二進位來表示,共有256中,加入些拉丁文等字元,1bytes代表一個字元,

Unicode是為了統一世界各國語言的不用,統一用2個bytes代表一個字元,可以表達2**16=65556個,稱為萬國語言,特點:速度快,但浪費空間,

可以用在記憶體處理中,相容了utf-8,gbk,ASCII,

utf-8 為了改變Unicode的這種缺點,規定1個英文字元用1個位元組表示,1個中文字元用3個位元組表示,特點;節省空間的,速度慢,用在硬碟資料轉送,網路資料轉送,相比硬碟和網路速度,體現不出來的,

gbk  是中文的字元編碼,用2個位元組代表一個字元,

 

4、請寫出 “李傑” 分別用 utf-8 和 gbk 編碼所佔的位元

utf-8    是3 bytes=24bit

gbk     是2bytes=16bit

 

5、Pyhton 單行注釋和多行注釋分別用什麼?

單行注釋  #

多行注釋  """  """三個雙引號或是三個單 引號把要解釋的內容放中間, ‘’‘  ’’’

 

6、聲明變數注意事項有那些?

萬能避錯規則,以小寫字母開頭命名,可以加上底線,或者數字,

不能以Python的關鍵字命名,

能表明變數的意義

 

8、如何查看變數在記憶體中的地址?

 

z=1
print(id(z))
9、執行 Python 程式時,自動產生的 .pyc 檔案的作用是什麼?

.pyc 是編譯py檔案後的二進位檔案,用於加速運行

 

10、寫代碼
a.實現使用者輸入使用者名稱和密碼,當使用者名稱為 seven 且 密碼為 123 時,顯示登陸成功,否則登陸失敗!

 



name=input(‘name:‘).strip()
pwd=input(‘pwd:‘).strip()
if name==‘seven‘ and pwd==‘123‘ :
print(‘ok‘)
else:
print(‘error‘)

b.實現使用者輸入使用者名稱和密碼,當使用者名稱為 seven 且 密碼為 123 時,顯示登陸成功,否則登陸失敗,失敗時允許重複輸入三次

while迴圈:
count=1
while count<=3 :
name = input(‘name:‘).strip()
pwd = input(‘pwd:‘).strip()

if name==‘seven‘ and pwd==‘123‘ :
print(‘ok‘)
else:
print(‘error‘)
count += 1
for迴圈:
for count in range(3) :
name = input(‘name:‘).strip()
pwd = input(‘pwd:‘).strip()

if name==‘seven‘ and pwd==‘123‘ :
print(‘ok‘)
else:
print(‘error‘)
count += 1
c.實現使用者輸入使用者名稱和密碼,當使用者名稱為 seven 或 alex 且 密碼為 123 時,顯示登陸成功,否則登陸失敗,失敗時允許重複輸入三次

while 迴圈
count =1
while count<=3 :
name = input(‘name: ‘)
pwd = input(‘pwd: ‘)
if name == ‘seven‘ and pwd == ‘123‘ or name == ‘alex‘ and pwd == ‘123‘:
print(‘ok‘)
else :
print(‘error‘)
count+=1
for迴圈
for count in range(3)  :
name = input(‘name: ‘)
pwd = input(‘pwd: ‘)
if name == ‘seven‘ and pwd == ‘123‘ or name == ‘alex‘ and pwd == ‘123‘:
print(‘ok‘)
else :
print(‘error‘)
count+=1
11、寫代碼
a. 使用while迴圈實現輸出2-3+4-5+6...+100 的和

 

count=2
num=0
while count<=100 :
if count % 2 ==0 :
num=count+num
count+=1
else:
num=num-count
count+=1
print(num)

b. 使用for迴圈和range實現輸出 1-2+3-4+5-6...+99 的和
 num=0
count=1
for count in range(100) :
if count % 2 == 0 :
num=num - count
else :
num=num+count
print(num)

 

 c. 使用 while 迴圈實現輸出 1,2,3,4,5, 7,8,9, 11,12

 

count=1
while count < 13 :
if count !=6 :
if count !=10 :
print(count)

count+=1
d. 使用 while 迴圈實現輸出 1-100 內的所有奇數

 

for i in range(101) :
if i %2 != 0 :
print(i)

count=0
while count<100 :
if count %2 != 0 :
print(count)
count += 1

 

 

e. 使用 while 迴圈實現輸出 1-100 內的所有偶數

 

for i in range(100) :
if i %2 == 0:
print(i)

count=0
while count<100 :
if count%2 == 0 :
print(count)
count+=1

12、分別書寫數字 5,10,32,7 的二進位表示

 

 

print(bin(5))二進位   0b101

print(hex(10))十六進位  0x5
print(oct(5)) 八進位 0o5
14、現有如下兩個變數,請簡述 n1 和 n2 是什麼關係? n1 = 123 n2 = 123

n1,n2是連個不同的變數名,但值都一樣,都指向了同一個記憶體位址,

 

16、現有如下兩個變數,請簡述 n1 和 n2 是什麼關係? n1 = 123456 n2 = n1n2賦值給n1.指向同一個記憶體位址,

 

17、如有一下變數 n1 = 5,請使用 int 的提供的方法,得到該變數最少可以用多少個二進位位表示?

 n1=5
print(int.bit_length(n1))  結果  3

 

 

18、布爾值分別有什麼?

False .Ture ,或1  和0

 

20、寫代碼,有如下變數,請按照要求實現每個功能 name = " aleX"
a. 移除 name 變數對應的值兩邊的空格,並輸入移除有的內容
print(name.strip())

b. 判斷 name 變數對應的值是否以 "al" 開頭,並輸出結果

 

print(name.startswith(‘al‘))
c. 判斷 name 變數對應的值是否以 "X" 結尾,並輸出結果

print(name.endswith(‘x‘))
d. 將 name 變數對應的值中的 “l” 替換為 “p”,並輸出結果

 

print(name.replace(‘l‘,‘p‘))   apex  
e. 將 name 變數對應的值根據 “l” 分割,並輸出結果。

 

print(name.split(‘e‘))   [‘al‘, ‘x  ‘]  列表

 

g. 將 name 變數對應的值變大寫,並輸出結果

print(name.upper())  print(name.lower())
i. 請輸出 name 變數對應的值的第 2 個字元?
print(name[1])

j. 請輸出 name 變數對應的值的前 3 個字元?

print(name[:3])
k. 請輸出 name 變數對應的值的後 2 個字元?
 
l. 請輸出 name 變數對應的值中 “e” 所在索引位置?

print(name.index(‘e‘))
21、字串是否可迭代?如可以請使用 for 迴圈每一個元素?

 

依賴索引
name = "Alex "
for i in range(len(name)) :
print(name[i])

 


for i in name:
print(i)
22、請用代碼實現:利用底線將列表的每一個元素拼接成字串,li = [‘alex‘, ‘eric‘, ‘rain‘]

print(‘_‘.join([‘alex‘, ‘eric‘, ‘rain‘]))    alex_eric_rain
22、寫代碼,有如下列表,按照要求實現每一個功能 li = [‘alex‘, ‘eric‘, ‘rain‘]

li = [‘alex‘, ‘eric‘, ‘rain‘]
print(len(li))
b. 列表中追加元素 “seven”,並輸出添加後的列表

li.append(‘seven‘)      
print(li)

 [‘alex‘, ‘eric‘, ‘rain‘, ‘seven‘]
c. 請在列表的第 1 個位置插入元素 “Tony”,並輸出添加後的列表

li.insert(0,‘TONY‘)
print(li)
d. 請修改列表第 2 個位置的元素為 “Kelly”,並輸出修改後的列表

li[1]=(‘killy‘)
print(li)
e. 請刪除列表中的元素 “eric”,並輸出修改後的列表

li = [‘alex‘, ‘eric‘, ‘rain‘]
li.pop(1)
print(li) [‘alex‘, ‘rain‘]
指名道姓的刪除
li = [‘alex‘, ‘eric‘, ‘rain‘]
li.remove(‘alex‘)
print(li)
f. 請刪除列表中的第 2 個元素,並輸出刪除的元素的值和刪除元素後的列表

li = [‘alex‘, ‘eric‘, ‘rain‘]
print(li.pop(1))
print(li)

eric
[‘alex‘, ‘rain‘]
h. 請刪除列表中的第 2 至 4 個元素,並輸出刪除元素後的列表
li = [‘alex‘, ‘eric‘, ‘rain‘]

del li[1:]
print(li) k. 請使用 enumrate 輸出資料行表元素和序號(序號從 100 開始)

li = [‘alex‘, ‘eric‘, ‘rain‘]
for k,v in enumerate(li,1):
print(k,v)
23、寫代碼,有如下列表,請按照功能要求實現每一個功能 li = ["hello", ‘seven‘, ["mon", ["h", "kelly"], ‘all‘], 123, 446]

a. 請輸出 “Kelly”

 

li = ["hello", ‘seven‘, ["mon", ["h", "kelly"], ‘all‘], 123, 446]
print(li[2][1][1])

 


b. 請使用索引找到 ‘all‘ 元素並將其修改為 “ALL”
li[2][2]=‘ALL‘
print(li)
24、寫代碼,有如下元組,按照要求實現每一個功能 tu = (‘alex‘, ‘eric‘, ‘rain‘)
a. 計算元組長度並輸出

tu = (‘alex‘, ‘eric‘, ‘rain‘)
print(len(tu))
b. 擷取元組的第 2 個元素,並輸出

 

print(tu[1])
e. 請使用 for、len、range 輸出元組的索引

 

for i in range(len(tu)) :
print(tu.index(tu[i]))
f. 請使用 enumrate 輸出元祖元素和序號(序號從 10 開始)

 


for k,v in enumerate(tu,10) :
print(k,v)
10 alex
11 eric
12 rain

for k in enumerate(tu,10) :
print(k)
(10, ‘alex‘)
(11, ‘eric‘)
(12, ‘rain‘)


25、有如下變數,請實現要求的功能
tu = ("alex", [11, 22, {"k1": ‘v1‘, "k2": ["age", "name"], "k3": (11,22,33)}, 44])
c. 請問 tu 變數中的"k2"對應的值是什麼類型?是否可以被修改?如果可以,請在其中添加一個元素 “Seven”

元組,不可以

 

d. 請問 tu 變數中的"k3"對應的值是什麼類型?是否可以被修改?如果可以,請在其中添加一個元素 “Seven”

列表,可以
tu = ("alex", [11, 22, {"k1": ‘v1‘, "k2": ["age", "name"], "k3": (11,22,33)}, 44])
res=tu[1][2][‘k2‘].append(‘seven‘)

print(tu)
26、字典
dic = {‘k1‘: "v1", "k2": "v2", "k3": [11,22,33]}

for i in dic:
print(i)
b. 請迴圈輸出所有的 value

 

for i in dic:
print(dic[i])
c. 請迴圈輸出所有的 key 和 value
for i in dic:

print(i,dic[i])

 

d. 請在字典中添加一個索引值對,"k4": "v4",輸出添加後的字典

 

dic[‘k4‘]=‘v4‘
print(dic)
e. 請在修改字典中 “k1” 對應的值為 “alex”,輸出修改後的字典

 

dic[‘k1‘]=‘alex‘
print(dic)
f. 請在 k3 對應的值中追加一個元素 44,輸出修改後的字典

 

dic[‘k3‘].append(44)
print(dic)

 

 

g. 請在 k3 對應的值的第 1 個位置插入個元素 18,輸出修改後的字典

 

dic[‘k3‘].insert(0,44)
print(dic)
27、轉換
a. 將字串 s = "alex" 轉換成列表  
s = "alex"

print(list(s))
b. 將字串 s = "alex" 轉換成元祖

 

s = "alex"
print(tuple(s))

b. 將列表 li = ["alex", "seven"] 轉換成元組

 

li = ["alex", "seven"]
print(tuple(li))
c. 將元祖 tu = (‘Alex‘, "seven") 轉換成列表

 

tu = (‘Alex‘, "seven")
li=list(tu)
print(li)

 

 

 


d. 將列表 li = ["alex", "seven"] 轉換成字典且字典的 key 按照 10 開始向後遞增

dic={}
for k,v in enumerate(li,10) :----li要放在前面,序號放在後面
dic[k]=v
print(dic)
27、轉碼n = "老男孩"

a. 將字串轉換成 utf-8 編碼的位元組,並輸出,然後將該位元組再轉換成 utf-8 編碼字串,再輸出n = "老男孩"
a=n.encode(‘utf-8‘)   
print(a)
b=a.decode(‘utf-8‘)
print(b)
b. 將字串轉換成 gbk 編碼的位元組,並輸出,然後將該位元組再轉換成 gbk 編碼字串,再輸出
a=n.encode(‘gbk‘)
print(a)
b=a.decode(‘gbk‘)
print(b)
28、求 1-100 內的所有數的和

 

count=1
sum=0
for i in range(100) :
sum=sum+count
count+=1
print(sum)

count=1
sum=0
while count<=100 :
sum+=count
count+=1
print(sum)
29、元素分類
有如下值集合 [11,22,33,44,55,66,77,88,99,90],將所有大於 66 的值儲存至字典的第一個 key 中,
將小於 66 的值儲存至第二個 key 的值中。
即: {‘k1‘: 大於 66 的所有值, ‘k2‘: 小於 66 的所有值}

 

li=[11,22,33,44,55,66,77,88,99,90]
dic1={
‘max‘:[],
‘min‘:[]
}
for i in li :
if i <66 :
dic1[‘min‘].append(i)
else:
dic1[‘max‘].append(i)
print(dic1)

---{‘max‘: [66, 77, 88, 99, 90], ‘min‘: [11, 22, 33, 44, 55]}

Python基礎知識匯總

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.