亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python 專題二 條件語句和循環(huán)語句的基礎知識

 更新時間:2017年03月19日 15:11:10   作者:Eastmount  
本文主要介紹了Python條件語句和循環(huán)語句的基礎知識。主要內(nèi)容包括: 1.條件語句:包括單分支、雙分支和多分支語句,if-elif-else;2.循環(huán)語句:while的使用及簡單網(wǎng)絡刷博器爬蟲;3.循環(huán)語句:for的使用及遍歷列表、元組、文件和字符串。

前面講述了"專題一.函數(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原始字符串(raw strings)用法實例

    Python原始字符串(raw strings)用法實例

    這篇文章主要介紹了Python原始字符串(raw strings)用法實例,在使用Python進行字符串處理的過程中非常具有實用價值,需要的朋友可以參考下
    2014-10-10
  • 利用Python實現(xiàn)定時程序的方法

    利用Python實現(xiàn)定時程序的方法

    在 Python 中,如何定義一個定時器函數(shù)呢?本文主要介紹了2種方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • 對python .txt文件讀取及數(shù)據(jù)處理方法總結(jié)

    對python .txt文件讀取及數(shù)據(jù)處理方法總結(jié)

    下面小編就為大家分享一篇對python .txt文件讀取及數(shù)據(jù)處理方法總結(jié),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-04-04
  • pytorch?tensor合并與分割方式

    pytorch?tensor合并與分割方式

    這篇文章主要介紹了pytorch?tensor合并與分割方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-02-02
  • 一篇文章入門Python生態(tài)系統(tǒng)(Python新手入門指導)

    一篇文章入門Python生態(tài)系統(tǒng)(Python新手入門指導)

    原文寫于2011年末,雖然文中關(guān)于Python 3的一些說法可以說已經(jīng)不成立了,但是作為一篇面向從其他語言轉(zhuǎn)型到Python的程序員來說,本文對Python的生態(tài)系統(tǒng)還是做了較為全面的介紹
    2015-12-12
  • 批處理與python代碼混合編程的方法

    批處理與python代碼混合編程的方法

    這篇文章主要介紹了批處理與python代碼混合編程的方法的相關(guān)資料,非常不錯,具有參考價值,感興趣的朋友一起學習吧
    2016-05-05
  • 關(guān)于最大池化層和平均池化層圖解

    關(guān)于最大池化層和平均池化層圖解

    這篇文章主要介紹了關(guān)于最大池化層和平均池化層圖解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • 解讀Tensorflow2.0訓練損失值降低,但測試正確率基本不變的情況

    解讀Tensorflow2.0訓練損失值降低,但測試正確率基本不變的情況

    這篇文章主要介紹了Tensorflow2.0訓練損失值降低,但測試正確率基本不變的情況,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • python中opencv?直方圖處理

    python中opencv?直方圖處理

    這篇文章主要介紹了python中opencv?直方圖處理,直方圖從圖像內(nèi)部灰度級的角度對圖像進行表述,直方圖是圖像內(nèi)灰度值的統(tǒng)計特性與圖像灰度值之間的函數(shù),直方圖統(tǒng)計圖像內(nèi)各個灰度級出現(xiàn)的次數(shù),更多相關(guān)內(nèi)容需要的小伙伴可以參考一下
    2022-06-06
  • python統(tǒng)計函數(shù)被調(diào)用次數(shù)的實現(xiàn)

    python統(tǒng)計函數(shù)被調(diào)用次數(shù)的實現(xiàn)

    本文主要介紹了python如何統(tǒng)計函數(shù)被調(diào)用次數(shù),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-02-02

最新評論