Python 專題二 條件語句和循環(huán)語句的基礎知識
前面講述了"專題一.函數(shù)的基礎知識",而這篇文章講述的Python的條件語句和循環(huán)語句的基礎知識.主要內(nèi)容包括:
1.條件語句:包括單分支、雙分支和多分支語句,if-elif-else
2.循環(huán)語句:while的使用及簡單網(wǎng)絡刷博器爬蟲
3.循環(huán)語句:for的使用及遍歷列表、元組、文件和字符串
前言: 語句塊
在講訴條件語句、循環(huán)語句和其他語句之前,先來補充語句塊知識.(前面講函數(shù)時已經(jīng)用到過)
語句塊并非一種語句,它是在條件為真(條件語句)時執(zhí)行或執(zhí)行多次(循環(huán)語句)的一組語句.在代碼前放置空格或tab字符來縮進語句即可創(chuàng)建語句塊.很多語言特殊單詞或字符(如begin或{)來表示一個語句塊的開始,用另外的單詞或字符(如end或})來表示語句塊的結(jié)束.
而在Python中使用冒號(:)來標識語句塊的開始,塊中每一個語句都是縮進的(縮進量相同).當回退到和已經(jīng)閉合的塊一樣的縮進量時,就表示當前塊已經(jīng)結(jié)束.
一. 條件語句if
if分支語句表達式基本類型常見的有一下三種:
1.單分支語句
它的基本格式是:
if condition: statement statement
需要注意的是Ptthon中if條件語句條件無需圓括號(),條件后面需要添加冒號,它沒有花括號{}而是使用TAB實現(xiàn)區(qū)分.其中condition條件判斷通常有布爾表達式(True|False 0-假|(zhì)1-真 非0即真)、關(guān)系表達式(>= <= == !=)和邏輯運算表達式(and or not).
2.雙分支語句
它的基本格式是:
if condition: statement statement else: statement statement
3.多分支語句
if多分支由if-elif-else組成,其中elif相當于else if,同時它可以使用多個if的嵌套.具體代碼如下所示:
#雙分支if-else count = input("please input:") print 'count=',count if count>80: print 'lager than 80' else: print 'lower than 80' print 'End if-else' #多分支if-elif-else number = input("please input:") print 'number=',number if number>=90: print 'A' elif number>=80: print 'B' elif number>=70: print 'C' elif number>=60: print 'D' else: print 'No pass' print 'End if-elif-else' #條件判斷 sex = raw_input("plz input your sex:") if sex=='male' or sex=='m' or sex=='man': print 'Man' else: print 'Woman'
二. 循環(huán)語句while
while循環(huán)語句的基本格式如下:
while condition: statement statement else: statement statement
其中判斷條件語句condition可以為布爾表達式、關(guān)系表達式和邏輯表達式,else可以省略(此處列出為與C語言等區(qū)別).舉個例子:
#循環(huán)while計數(shù)1+2+..+100 i = 1 s = 0 while i <= 100: s = s+i i = i+1 else: print 'exit while' print 'sum = ',s ''''' 輸出結(jié)果為:exit while sum = 5050 '''
它的輸出結(jié)果為5050,當時當i加到101時,由于i>100將執(zhí)行else語句.
需要注意的是Python中使用井號(#)表示行注釋,使用三引號('''...''')表示多行注釋.區(qū)別于C/C++的//行注釋和/**/多行注釋.
下面講述一段代碼刷博器爬蟲,先給出代碼再講解:
import webbrowser as web import time import os i=0 while i<5: web.open_new_tab('http://andy111.blog.sohu.com/46684846.html') i=i+1 time.sleep(0.8) else: os.system('taskkill /F /IM iexplore.exe') print 'close IE'
在搜狐博客或新浪博客中只要在新窗口打開就會增加瀏覽訪問次數(shù),所以上面的代碼主要是通過調(diào)用webbrowser瀏覽器的open_new_tab打開新的窗口,而CSDN不行(估計綁定用戶或ip有關(guān)).
上面代碼中windoes命令taskkill的作用是殺掉應用程序IE瀏覽器,在DOS中輸入"taskkill /F /IM iexplore.exe"可以強行關(guān)閉應用程序(chrome.exe或qq.exe),其中/F表示強行終止程序,/IM表示圖像.在該程序中主要的作用是清除內(nèi)存,防止內(nèi)存消耗太大出現(xiàn)死機現(xiàn)象;但是需要調(diào)用import os的system()函數(shù)打開,而Linux下用kill命令(kill -pid或killall)終止進程.
代碼中time.sleep(seconds)表示"Delay execution for a given number of seconds.",從打開到加載有一定時間.
當你需要大量增加瀏覽量時可以使用兩層循環(huán)嵌套,每次打開5個網(wǎng)頁在關(guān)閉在執(zhí)行100次,這樣你的內(nèi)存也不會因為消耗太大出現(xiàn)死機現(xiàn)象,也可以使用import random count=random.randint(20,40)產(chǎn)生20到40隨機數(shù)來執(zhí)行外層循環(huán).代碼比較簡單,主要是想通過它介紹些Python的基礎知識.但是初次打開IE瀏覽器會出現(xiàn)打開次數(shù)不一致的錯誤.why?
三. 循環(huán)語句for
該循環(huán)語句的基礎格式為:
for target in sequences: statements
target表示變量名,sequences表示序列,常見類型有l(wèi)ist(列表)、tuple(元組)、strings(字符串)和files(文件).
Python的for沒有體現(xiàn)出循環(huán)的次數(shù),不像C語言的for(i=0;i<10;i++)中i循環(huán)計數(shù),Python的for指每次從序列sequences里面的數(shù)據(jù)項取值放到target里,取完即結(jié)束,取多少次循環(huán)多少次.其中in為成員資格運算符,檢查一個值是否在序列中.同樣可以使用break和continue跳出循環(huán).
1.字符串循環(huán)
s1 = 'Eastmount of CSDN' for c in s1: print c,
注意:如果在print結(jié)尾加上逗號,那么接下來語句會與前一條語句在同一行打印.故上面輸出顯示一行.
2.列表循環(huán)
list1 = [1,3,4,5,'x',12.5] i = 0 for val in list1: print format(i,'2d'),val i = i+1 else: print 'out for'
注意:列表List由一堆數(shù)據(jù)用逗號間隔,方括號括起,可以是同類型也可以是不同類型.format(i,'2d')相當于輸出兩位,不足的補空格.當輸出0-9時顯示"口0",而輸出10-99時顯示"10"實現(xiàn)對其功能.輸出結(jié)果如下:
1 3 2 4 3 5 4 x 5 12.5 ut for
因為迭代(循環(huán)另一種說法)某范圍的數(shù)字是很常用的,所以有個內(nèi)建的范圍函數(shù)range供使用.列表中for n in [1,2,3,4,5,6,7,8]相當于listNum=range(1,9).其格式"range(start, stop[, step]) -> list of integers",它的工作方式類似于分片,它包含下限(本例range(1,9)中為1),但不包含上限(本例中9),如果希望下限為0,可以只提供上限如range(4)=[0,1,2,3].
產(chǎn)生1到100的數(shù)字range(1,101),輸出1到100的奇數(shù)range(1,101,2),輸出1到100的偶數(shù)range(2,101,2).
3.元組循環(huán)
tup = (1,2,3,4,5) for n in tup: print n else: print 'End for'
元組tuple每個數(shù)據(jù)項不可修改,只可讀,而序列l(wèi)ist[1,2,3,4]可以修改.
4.文件循環(huán)
help(file.read)返回一個字符串."read([size]) -> read at most size bytes, returned as a string."
help(file.readlines)返回一個列表."readlines([size]) -> list of strings, each a line from the file."相當于讀n行,由n次readline組成,讀出的字符串構(gòu)成列表.
help(file.readline)從某個文件讀一行."readline([size]) -> next line from the file, as a string."
#文件循環(huán)遍歷三種對比 for n in open('for.py','r').read(): print n, print 'End' for n in open('for.py','r').readlines(): print n, print 'End' for n in open('for.py','r').readline(): print n, print 'End'
輸出顯示:
#第一個read()輸出:每個字符間有個空格 s 1 = ' E a s t m o u n t o f C S D N ' f o r c i n s 1 : .... End #第二個readlines()輸出:讀取的是一行 s1 = 'Eastmount of CSDN' for c in s1: .... End #第三個readline()輸出:讀取for.py文件第一行并輸出 s 1 = ' E a s t m o u n t o f C S D N ' End
如果需要文件輸出也可以通過下面代碼實現(xiàn),使用w會覆蓋而a+是追加功能,后面講文件詳細敘述.
for r in open('test.txt','r').readlines(): open('test.txt','a+').write(c)
PS:我主要是通過《Python基礎教程》和"51CTO學院 智普教育的python視頻"學習.所以文中引用了很多視頻中的知識、書籍知識和自己的知識,感謝那些作者和老師,希望文章對大家有所幫助,才開始學習python知識,如果文章中有錯誤或不足之處,還請海涵,也希望大家提出意見與君共勉.勿噴~
以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
相關(guān)文章
對python .txt文件讀取及數(shù)據(jù)處理方法總結(jié)
下面小編就為大家分享一篇對python .txt文件讀取及數(shù)據(jù)處理方法總結(jié),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-04-04一篇文章入門Python生態(tài)系統(tǒng)(Python新手入門指導)
原文寫于2011年末,雖然文中關(guān)于Python 3的一些說法可以說已經(jīng)不成立了,但是作為一篇面向從其他語言轉(zhuǎn)型到Python的程序員來說,本文對Python的生態(tài)系統(tǒng)還是做了較為全面的介紹2015-12-12解讀Tensorflow2.0訓練損失值降低,但測試正確率基本不變的情況
這篇文章主要介紹了Tensorflow2.0訓練損失值降低,但測試正確率基本不變的情況,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06python統(tǒng)計函數(shù)被調(diào)用次數(shù)的實現(xiàn)
本文主要介紹了python如何統(tǒng)計函數(shù)被調(diào)用次數(shù),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-02-02