python

Python簡介

python的創始人爲吉多·範羅蘇姆(Guido van Rossum)。1989年的聖誕節期間,吉多·範羅蘇姆(中文名字:龜叔)爲了在阿姆斯特丹打發時間,決心開發一個新的腳本解釋程序,做爲ABC語言的一種繼承。  html

(龜叔:2005年加入谷歌至2012年,2013年加入Dropbox直到如今,依然掌握着Python發展的核心方向,被稱爲仁慈的獨裁者)。java

2018年9月的TIOBE排行榜,Python已經佔據第四的位置, Python崇尚優美、清晰、簡單,是一個優秀並普遍使用的語言。python

由上圖可見,Python總體呈上升趨勢,反映出Python應用愈來愈普遍而且也逐漸獲得業內的承認!!!c++

Python能夠應用於衆多領域,如:數據分析、組件集成、網絡服務、圖像處理、數值計算和科學計算等衆多領域。目前業內幾乎全部大中型互聯網企業都在使用Python,如:Youtube、Dropbox、BT、Quora(中國知乎)、豆瓣、知乎、Google、Yahoo!、Facebook、NASA、百度、騰訊、汽車之家、美團等。web

目前Python主要應用領域

  • 雲計算: 雲計算最火的語言, 典型應用OpenStack
  • WEB開發: 衆多優秀的WEB框架,衆多大型網站均爲Python開發,Youtube, Dropbox, 豆瓣。。。, 典型WEB框架有Django
  • 科學運算、人工智能: 典型庫NumPy, SciPy, Matplotlib, Enthought librarys,pandas
  • 系統運維: 運維人員必備語言
  • 爬蟲:經過代碼來模擬人類訪問網頁,選擇有用信息進行下載
  • 金融:量化交易,金融分析,在金融工程領域,Python不但在用,且用的最多,並且重要性逐年提升。緣由:做爲動態語言的Python,語言結構清晰簡單,庫豐富,成熟穩定,科學計算和統計分析都很牛逼,生產效率遠遠高於c,c++,java,尤爲擅長策略回測
  • 圖形GUI: PyQT, WxPython,TkInter

Python在一些公司的應用 

  • 谷歌:Google App Engine 、code.google.com 、Google earth 、谷歌爬蟲、Google廣告等項目都在大量使用Python開發
  • CIA: 美國中情局網站就是用Python開發的
  • NASA: 美國航天局(NASA)大量使用Python進行數據分析和運算
  • YouTube:世界上最大的視頻網站YouTube就是用Python開發的
  • Dropbox:美國最大的在線雲存儲網站,所有用Python實現,天天網站處理10億個文件的上傳和下載
  • Instagram:美國最大的圖片分享社交網站,天天超過3千萬張照片被分享,所有用python開發
  • Facebook:大量的基礎庫均經過Python實現的
  • Redhat: 世界上最流行的Linux發行版本中的yum包管理工具就是用python開發的
  • 豆瓣: 公司幾乎全部的業務均是經過Python開發的
  • 知乎: 國內最大的問答社區,經過Python開發(國外Quora)
  • 春雨醫生:國內知名的在線醫療網站是用Python開發的
  • 除上面以外,還有搜狐、金山、騰訊、盛大、網易、百度、阿里、淘寶 、土豆、新浪、果殼等公司都在使用Python完成各類各樣的任務。 

python發展史

  • 1989年,爲了打發聖誕節假期,Guido開始寫Python語言的編譯器。Python這個名字,來自Guido所摯愛的電視劇Monty Python’s Flying Circus。他但願這個新的叫作Python的語言,能符合他的理想:創造一種C和shell之間,功能全面,易學易用,可拓展的語言。
  • 1991年,第一個Python編譯器誕生。它是用C語言實現的,並可以調用C語言的庫文件。從一出生,Python已經具備了:類,函數,異常處理,包含表和詞典在內的核心數據類型,以及模塊爲基礎的拓展系統。
  • Granddaddy of Python web frameworks, Zope 1 was released in 1999
  • Python 1.0 - January 1994 增長了 lambdamapfilter and reduce.
  • Python 2.0 - October 16, 2000,加入了內存回收機制,構成了如今Python語言框架的基礎
  • Python 2.4 - November 30, 2004, 同年目前最流行的WEB框架Django 誕生
  • Python 2.5 - September 19, 2006
  • Python 2.6 - October 1, 2008
  • Python 2.7 - July 3, 2010
  • In November 2014, it was announced that Python 2.7 would be supported until 2020, and reaffirmed that there would be no 2.8 release as users were expected to move to Python 3.4+ as soon as possible
  • Python 3.0 - December 3, 2008
  • Python 3.1 - June 27, 2009
  • Python 3.2 - February 20, 2011
  • Python 3.3 - September 29, 2012
  • Python 3.4 - March 16, 2014
  • Python 3.5 - September 13, 2015
  • Python 3.6 - December 16,2016

python是什麼編程語言

        編程語言主要從如下幾個角度爲進行分類,編譯型和解釋型、靜態語言和動態語言、強類型定義語言和弱類型定義語言,每一個分類表明什麼意思呢,咱們一塊兒來看一下。算法

編譯型與解釋型shell

  編譯器是把源程序的每一條語句都編譯成機器語言,並保存成二進制文件,這樣運行時計算機能夠直接以機器語言來運行此程序,速度很快; 編程

  而解釋器則是隻在執行程序時,才一條一條的解釋成機器語言給計算機來執行,因此運行速度是不如編譯後的程序運行的快的. 安全

  這是由於計算機不能直接認識並執行咱們寫的語句,它只能認識機器語言(是二進制的形式)網絡

 

編譯型
    優勢:編譯器通常會有預編譯的過程對代碼進行優化。由於編譯只作一次,運行時不須要編譯,因此編譯型語言的程序執行效率高。能夠脫離語言環境獨立運行。

    缺點:編譯以後若是須要修改就須要整個模塊從新編譯。編譯的時候根據對應的運行環境生成機器碼,不一樣的操做系統之間移植就會有問題,須要根據運行的操做系統環境編譯不一樣的可執行文件。

解釋型
    優勢:有良好的平臺兼容性,在任何環境中均可以運行,前提是安裝瞭解釋器(虛擬機)。靈活,修改代碼的時候直接修改就能夠,能夠快速部署,不用停機維護。

    缺點:每次運行的時候都要解釋一遍,性能上不如編譯型語言。

動態語言和靜態語言

    一般咱們所說的動態語言、靜態語言是指動態類型語言和靜態類型語言。

  (1)動態類型語言:動態類型語言是指在運行期間纔去作數據類型檢查的語言,也就是說,在用動態類型的語言編程時,永遠也不用給任何變量指定數據類型,該語言會在你第一次賦值給變量時,

    在內部將數據類型記錄下來。Python和Ruby就是一種典型的動態類型語言,其餘的各類腳本語言如VBScript也多少屬於動態類型語言。

  (2)靜態類型語言:靜態類型語言與動態類型語言恰好相反,它的數據類型是在編譯其間檢查的,也就是說在寫程序時要聲明全部變量的數據類型,C/C++是靜態類型語言的典型表明,

    其餘的靜態類型語言還有C#、JAVA等。

強類型定義語言和弱類型定義語言

  (1)強類型定義語言:強制數據類型定義的語言。也就是說,一旦一個變量被指定了某個數據類型,若是不通過強制轉換,那麼它就永遠是這個數據類型了。

    舉個例子:若是你定義了一個整型變量a,那麼程序根本不可能將a看成字符串類型處理。強類型定義語言是類型安全的語言。

  (2)弱類型定義語言:數據類型能夠被忽略的語言。它與強類型定義語言相反, 一個變量能夠賦不一樣數據類型的值。

    強類型定義語言在速度上可能略遜色於弱類型定義語言,可是強類型定義語言帶來的嚴謹性可以有效的避免許多錯誤。另外,「這門語言是否是動態語言」與「這門語言是否類型安全」之間是徹底沒有聯繫的!

         例如:Python是動態語言,是強類型定義語言(類型安全的語言); VBScript是動態語言,是弱類型定義語言(類型不安全的語言); JAVA是靜態語言,是強類型定義語言(類型安全的語言)。

    經過上面這些介紹,咱們能夠得出,python是一門動態解釋性的弱類型定義語言。

python的優缺點

先看優勢

  1. Python的定位是「優雅」、「明確」、「簡單」,因此Python程序看上去老是簡單易懂,初學者學Python,不但入門容易,並且未來深刻下去,能夠編寫那些很是很是複雜的程序。
  2. 開發效率很是高,Python有很是強大的第三方庫,基本上你想經過計算機實現任何功能,Python官方庫裏都有相應的模塊進行支持,直接下載調用後,在基礎庫的基礎上再進行開發,大大下降開發週期,避免重複造輪子。
  3. 高級語言————當你用Python語言編寫程序的時候,你無需考慮諸如如何管理你的程序使用的內存一類的底層細節
  4. 可移植性————因爲它的開源本質,Python已經被移植在許多平臺上(通過改動使它可以工 做在不一樣平臺上)。若是你當心地避免使用依賴於系統的特性,那麼你的全部Python程序無需修改就幾乎能夠在市場上全部的系統平臺上運行
  5. 可擴展性————若是你須要你的一段關鍵代碼運行得更快或者但願某些算法不公開,你能夠把你的部分程序用C或C++編寫,而後在你的Python程序中使用它們。
  6. 可嵌入性————你能夠把Python嵌入你的C/C++程序,從而向你的程序用戶提供腳本功能。

再看缺點

  1. 速度慢,Python 的運行速度相比C語言確實慢不少,跟JAVA相比也要慢一些,所以這也是不少所謂的大牛不屑於使用Python的主要緣由,但其實這裏所指的運行速度慢在大多數狀況下用戶是沒法直接感知到的,必須藉助測試工具才能體現出來,好比你用C運一個程序花了0.01s,用Python是0.1s,這樣C語言直接比Python快了10倍,算是很是誇張了,可是你是沒法直接經過肉眼感知的,由於一個正常人所能感知的時間最小單位是0.15-0.4s左右,哈哈。其實在大多數狀況下Python已經徹底能夠知足你對程序速度的要求,除非你要寫對速度要求極高的搜索引擎等,這種狀況下,固然仍是建議你用C去實現的。
  2. 代碼不能加密,由於PYTHON是解釋性語言,它的源碼都是以名文形式存放的,不過我不認爲這算是一個缺點,若是你的項目要求源代碼必須是加密的,那你一開始就不該該用Python來去實現。
  3. 線程不能利用多CPU問題,這是Python被人詬病最多的一個缺點,GIL即全局解釋器鎖(Global Interpreter Lock),是計算機程序設計語言解釋器用於同步線程的工具,使得任什麼時候刻僅有一個線程在執行,Python的線程是操做系統的原生線程。在Linux上爲pthread,在Windows上爲Win thread,徹底由操做系統調度線程的執行。一個python解釋器進程內有一條主線程,以及多條用戶程序的執行線程。即便在多核CPU平臺上,因爲GIL的存在,因此禁止多線程的並行執行。關於這個問題的折衷解決方法,咱們在之後線程和進程章節裏再進行詳細探討。

當咱們編寫Python代碼時,咱們獲得的是一個包含Python代碼的以.py爲擴展名的文本文件。要運行代碼,就須要Python解釋器去執行.py文件。

因爲整個Python語言從規範到解釋器都是開源的,因此理論上,只要水平夠高,任何人均可以編寫Python解釋器來執行Python代碼(固然難度很大)。事實上,確實存在多種Python解釋器。

python的種類

  • Cpython

  Python的官方版本,使用C語言實現,使用最爲普遍,CPython實現會將源文件(py文件)轉換成字節碼文件(pyc文件),而後運行在Python虛擬機上。

  • Jyhton

  Python的Java實現,Jython會將Python代碼動態編譯成Java字節碼,而後在JVM上運行。

  • IronPython

    Python的C#實現,IronPython將Python代碼編譯成C#字節碼,而後在CLR上運行。(與Jython相似)

  • PyPy(特殊)

  Python實現的Python,將Python的字節碼字節碼再編譯成機器碼。

Python 的環境

Windows:

下載地址:https://www.python.org/downloads/

 

首先區分你當前的操做系統,而後選擇相對應的內容進行點擊,我當前操做系統是Windows我選擇的是普通電腦系統.下一步以下圖:

而後選擇和你電腦相對應的點擊,而後就自動下載了

安裝詳解

Linux:

自帶python環境

1
2
3
4
5
6
[meet@r usr]$ python37  - V
Python  3.7 . 0
[meet@r usr]$ python3  - V
Python  3.4 . 9
[meet@r usr]$ python2  - V
Python  2.7 . 5

更新python環境

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
1 、安裝gcc,用於編譯Python源碼
     yum install gcc
2 、下載源碼包,https: / / www.python.org / ftp / python /
3 、解壓並進入源碼文件
4 、編譯安裝
     . / configure
     make  all
     make install
5 、查看版本
     / usr / local / bin / python2. 7  - V
6 、修改默認Python版本
     mv  / usr / bin / python  / usr / bin / python2. 6
     ln  - / usr / local / bin / python2. 7  / usr / bin / python
7 、防止yum執行異常,修改yum使用的Python版本
     vi  / usr / bin / yum
     將頭部  #!/usr/bin/python 修改成 #!/usr/bin/python2.6 

Python 入門

1、'Hello World!'

1
2
3
4
5
python2寫法:   
         print  'hello world'
 
python3寫法:  
         print ( 'hello world' )

2、執行(解釋器)

明確的指出 hello.py 腳本由 python 解釋器來執行。執行Python代碼時,若是導入了其餘的 .py 文件,那麼,執行過程當中會自動生成一個與其同名的 .pyc 文件,該文件就是Python解釋器編譯以後產生的字節碼。

1
2
3
[meet@r usr]$ ls a.py *
a.py  a.pyc
[meet@r usr]$
1
2
3
#!/usr/bin/env python
  
print  "你好,世界"

改正:應該顯示的告訴python解釋器,用什麼編碼來執行源代碼,即:

1
2
3
4
#!/usr/bin/env python
# -*- coding: utf-8 -*-
  
print  "你好,世界"

3、變量

一、聲明變量

1
2
3
4
5
name  =  'Meet'
# 這樣的形式就是在定義一個變量
name 是一個變量名
=        是一個賦值操做
'Meet'  是一個值

變量的做用:暱稱其代指內存裏某個地址中保存的內容

 

變量定義的規則:

  • 變量名只能是 字母、數字或下劃線的任意組合
  • 變量名的第一個字符不能是數字
  • 如下關鍵字不能聲明爲變量名
  • ['and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'exec', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'not', 'or', 'pass', 'print', 'raise', 'return', 'try', 'while', 'with', 'yield']
  • 變量名建議不使用拼音和中文
  • 變量的要具備意義
  • 變量名不要過長
  • 變量名要區分大小寫
  • 變量名推薦寫法:
    • 駝峯體   MeetTheGirl
    • 下劃線   meet_the_girl

 

 

二、變量的賦值

1
2
name1  =  'Meet'
name2  =  'Guo'

 

1
2
name1  =  'Meet'
name2  =  name1

4、程序交互(用戶交互)

輸入用戶名

?
1
2
3
4
5
6
7
8
9
10
11
#!/usr/bin/env python
#-*- coding:utf-8 -*-
   
#將用戶輸入的內容賦值給name變量
python2的寫法
name = raw_input ( "請輸入用戶名:" )
print name
   
python3的寫法
name = input ( "請輸入用戶名:" )
print (name)

輸入密碼時,若是想要不可見,須要利用getpass 模塊中的 getpass方法,即:

?
1
2
3
4
5
6
#!/usr/bin/env python
#-*- coding:utf-8 -*-
   
import getpass
pwd = getpass.getpass( "請輸入密碼:" )
print (pwd)

注意:這個密碼不可見的方法只能在終端中實現

須要注意的是input程序交互獲取到的內容是字符串,咱們看下面的簡單示例:

?
1
2
3
4
5
6
7
8
9
10
11
12
num = input ( '請輸入數字:' )
print (num + 5 )
  
結果:
請輸入數字: 6
Traceback (most recent call last):
   File "D:/python_object/test.py" , line 350 , in <module>
     print (num + 5 )
TypeError: must be str , not int
  
# 報錯了,提示咱們類型錯誤,數字和字符串是不能相加的.但是咱們輸入的明明是數字啊.其實咱們看着輸入的是
# 數字可是input獲取到的都是字符串
 

變量的小高級

?
1
2
3
4
5
age1 = 18
age2 = age1
age1 = 12
age3 = age2
print (age1,age2,age3)

常量:

  常量就是將變量名大寫,儘可能保持不更改的一種量 

 

   
 

5、註釋

單行註釋:#Meet

多行註釋:'''Meet'''

?
1
2
3
4
5
6
7
8
9
10
單行註釋(當行註釋)
# Meet  
  
多行註釋
'''
M
e
e
t
'''  

6、基礎數據類型(int,str,bool)

int是整型;也就是咱們從小就接觸的數學中的整數,整型在計算機中運於計算和比較

在32位機器上int的範圍是:  -2**31~2**31-1,即-2147483648~2147483647

在64位機器上int的範圍是: -2**63~2**63-1,即-9223372036854775808~9223372036854775807

夠你用了吧. 注意這些是整數.

定義一個int類型
?
1
2
3
4
5
num1 = 2
num2 = 3
print (num1 + num2)
結果: 5  
# 整型就和咱們學的數學同樣能夠進行加減乘除

str是字符串;也就是咱們從小就接觸的中文,若是咱們在程序中直接把中文寫入,程序是不能分辨這是個什麼鬼東西.因此咱們要遵循一種規則

讓計算機可以識別,這個規則就是隻要是用引號引發來就是字符串

在Python中,凡是用引號引發來的,全是字符串.

數字類型有 +-*/ 字符串串有麼?

字符串只有 + *。

?
1
2
3
4
5
6
7
8
9
10
#字符串的拼接
 
s1 = 'a'
s2 = 'bc'
 
#print(s1 + s2)
#相乘
 
str * int name = '堅強'
#print(name*8

字符串能夠用單引號,雙引號,或者三引號引發來,沒有什麼區別,只是一些特殊的格式須要不用的引號 好比:

?
1
msg = "My name is Alex , I'm 22 years old!" 這個就須要單雙引號配合。
?
1
2
3
4
5
6
7
8
9
10
11
msg =
 
""" 今天我想寫首小詩,
 
歌頌個人同桌,
 
你看他那烏⿊的短髮,
 
好像⼀一隻炸毛雞。
 
"""

想多行賦值一個字符串,就須要三引號。

bool是布爾值;其實這個東西也是咱們很小就接觸的東西,俗話說人要<明辨是非>.其實這個bool值就是咱們所說的是非,布爾值中一共分爲倆個狀態

True   就對應咱們話中的是,白話來講就是真

False 就對應咱們話中的非,白話來講就是假

例如咱們想讓計算機幫咱們作一下倆個的大小比較

?
1
2
3
4
5
6
7
print ( 3 > 7 )
  
結果: False
  
print ( 7 > 3 )
  
結果: True

7、格式化輸出

如今有個須要咱們錄入咱們身邊好友的信息,格式以下:

?
1
2
3
4
5
6
- - - - - - - - - - - - info of Alex Li - - - - - - - - - -
              Name  : Alex Li
              Age   : 22
              job   : Teacher
              Hobbie: girl
     - - - - - - - - - - - - - end - - - - - - - - - - - - - - - -   

咱們如今能想到的辦法就是用一下方法:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
name = input ( '請輸入姓名:' )
age = input ( '請輸入年齡:' )
job = input ( '請輸入職業:' )
hobby = input ( '請輸入愛好:' )
a = '------------ info of Alex Li ----------'
b = 'Name:'
c = 'Age:'
d = 'Job:'
e = 'Hobby:'
f = '------------- end ----------------'
print (a +
       '\n' +
       b +
       name +
       '\n' +
       c +
       age +
       '\n' +
       d +
       job +
       '\n' +
       e +
       hobby +
       '\n' +
       f)
 
# 運行結果
- - - - - - - - - - - - info of Alex Li - - - - - - - - - -
Name:meet
Age: 18
Job:it
Hobby: 3
- - - - - - - - - - - - - end - - - - - - - - - - - - - - - -

這樣寫徹底沒有問題,可是會不會比較繁瑣呢,有些大佬確定會想這不都實現了嗎,還逼叨逼什麼啊,那是沒有體驗過格式化輸出有多霸道,咱們如今來體驗下霸道的姿式

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
name = input ( '請輸入姓名:' )
age = input ( '請輸入年齡:' )
job = input ( '請輸入職業:' )
hobby = input ( '請輸入愛好:' )
msg = '''
------------ info of Alex Li ----------
Name  : %s
Age   : %s
job   : %s
Hobbie: %s
------------- end ----------------
     
'''
print (msg % (name,age,job,hobby))

咱們但從代碼的數量來看,這樣就比那樣的少,看到這裏有細心的老鐵們確定在想%s這是啥玩意?

% 是一個佔位, 回想下咱們小時候給朋友佔位子的場景,是的這個就是佔位.那s又是什麼呢?  s代碼的字符串類型;

具體詳細參數以下,你們能夠參考一下

%c

轉換成字符(ASCII 碼值,或者長度爲一的字符串)

%r

優先用repr()函數進行字符串轉換

%s

優先用str()函數進行字符串轉換

%d / %i

轉成有符號十進制數

%u

轉成無符號十進制數

%o

轉成無符號八進制數

%x / %X

轉成無符號十六進制數(x / X 表明轉換後的十六進制字符的大小寫)

%e / %E

轉成科學計數法(e / E控制輸出e / E)

%f / %F

轉成浮點數(小數部分天然截斷)

%g / %G

%e和%f / %E和%F 的簡寫

%%

輸出% (格式化字符串裏面包括百分號,那麼必須使用%%)

%c格式化示例:

?
1
2
3
4
5
6
7
8
name = input ( '>>>' )
s = '1234%c' % name
print (s)
 
結果:
>>> 5
12345
# 注意點是 %c這個只支持一位數的格式化

%r格式化示例:

?
1
2
3
4
5
6
7
8
9
10
name = input ( '>>>' )
s = '1234%r' % name
print (s)
 
結果:
>>> 88
1234 '88'
 
# 注意看咱們輸入的88 用%r格式化後會有引號,這是由於調用了咱們內置的repr方法
repr 這個方法是讓編程人員快速分辨數據類型的方法

%d|%i格式化示例:

?
1
2
3
4
5
6
7
8
9
10
11
name = input ( '>>>' )
s1 = '1234%d' % int (name)
s2 = '1234%i' % int (name)
print (s1)
print (s2)
 
結果:
>>> 89
123489
123489
# %d和%i這種格式化只能用數字來填補佔位

%u格式化示例:

?
1
2
3
4
5
6
7
name = input ( '>>>' )
s1 = '1234%u' % int (name)
print (s1)
 
結果:
>>> 88
123488

%o格式化示例:

?
1
2
3
4
5
6
7
8
name = input ( '>>>' )
s1 = '1234%o' % int (name)
print (s1)
 
結果:
>>> 444
1234674
# 注意看我輸入的444可是卻不是444由於這樣給轉換成了8進制的數

%x|%X格式化示例:

?
1
2
3
4
5
6
7
8
9
10
name = input ( '>>>' )
s1 = '1234%x' % int (name)
s2 = '1234%X' % int (name)
print (s1)
print (s2)
 
結果:
>>> 78
12344e
12344E

%e|%E格式化示例:

?
1
2
3
4
5
6
7
8
9
10
name = input ( '>>>' )
s1 = '1234%e' % int (name)
s2 = '1234%E' % int (name)
print (s1)
print (s2)
 
結果:
>>> 7777
12347.777000e + 03
12347.777000E + 03

%f|%F格式化示例:

?
1
2
3
4
5
6
7
8
9
10
name = input ( '>>>' )
s1 = '1234%F' % int (name)
s2 = '1234%f' % int (name)
print (s1)
print (s2)
 
結果:
>>> 45
123445.000000
123445.000000

%%格式化示例:

?
1
2
3
4
5
6
7
8
9
num = input ( '>>>' )
s = '目前學習進度:%s%%' % num
print (s)
 
結果:
>>> 80
目前學習進度: 80 %
 
# 若是咱們字符串中想要顯示單獨的%就須要用來個%%來轉義,否則程序會認爲那是一個佔位

7、流程控制與縮進

判斷條件

?
1
2
3
age = input ( "輸入年齡:" )
if int (age) > = 18 :
     print ( "成年了,能幹成年人的事了" )

二選一遊戲(二者選其一)

 

以上這種寫法是讓用戶輸入內容,而後進行比較,若是一個條件成立那就執行print,爲了明確的區分改執行哪些部分,當條件成立後執行縮進的代碼

而後程序就退出了.下邊的else就不會在執行了

多個選項進行單選(選擇題)

?
1
2
3
4
5
6
7
num = input ( '請輸入要比較的數字:' )
if int (num) > = 22 :
     print ( '能夠扯證了' )
elif int (num) > = 18 :
     print ( '成年了,能夠幹一些成年的事了' )
elif int (num) < 18 :
     print ( '仍是小屁孩' )

以上寫法就是咱們作的單選題同樣,三個分支判斷中只要有個成立,其他都不在執行 

嵌套if

?
1
2
3
4
5
6
7
8
9
name = input ( '請輸入名字:' )
if name = = 'meet' :
     age = input ( '請輸入年齡:' )
     if int (age) = = 18 :
         print ( '輸入所有正確' )
     else :
         print ( '年齡輸入錯誤!' )
else :
     print ( '名字輸入錯誤!' )

這樣寫法很經常使用,這樣咱們就能夠明確的知道用戶輸入的名字和年齡那個是錯誤的,而且還作一個判斷若是名字正確後在進行判斷密碼

相關文章
相關標籤/搜索