Python的特點
Python是一門解釋性語言,它是多種語言的精華的集合,它從Perl(另外一種遠遠超越了標準的shell腳本的腳本語言),python的正則表達式引擎就是基于Perl(它最大的優勢就在于它的字符串模式匹配能力)。Python和java比較來說,他們都有類似的面向對象特性和語法,他們之間還誕生了一個可以在只有java環境中于運行Python程序的只用java編寫的Python解釋器Jython。JavaScript也是類似Python的面向對象腳本語言,但是JavaScript是基于原型設計的,Python是遵循面向對象系統,二者的類和對象有一些 差異。其他的就不記錄了,太多了,記錄主要的幾個自己知道的語言。
- 一般的Python解釋器是用C編寫的,又叫CPython
- 相對的用java編寫的就是前面提到的JPython,不作描述。
- IronPython,用C#語言完成,適用環境為.NET和Mono
- Stackless是針對CPython的修改。
Python起步
程序輸出
>>> 'hello'#交互式解釋器調用repr()函數來顯示對象
'hello'
>>> print('hello')#print語句調用str()函數顯示對象
hello
>>> print('姓名:%s 年齡:%d'%('python',23)) # 輸出格式化,占位符
姓名:python 年齡:23
>>> user = input() # 控制臺輸入
>? dlfkjs
>>> print(user)
dlfkjs
>>> 3+2
5
>>> 3-2
1
>>> 3 * 2
6
>>> 3 / 2
1.5
>>> 3 // 2 # 整除
1
>>> 3 ** 2 # 3的2次方
9
>>> 3 % 2 # 模
1
# 標準比較運算符
>>> 1 < 2
True
>>> 1 <= 2
True
>>> 1 > 2
False
>>> 1 >= 2
False
>>> 1 ==2
False
>>> 1 != 2
True
# 邏輯運算符
>>> 4>2 and 2>4 # 變種>>> 2 < 4 < 2
False
>>> 4>2 or 2>4
True
>>> not 2 > 4
True
>>> num = 4
>>> num *= 10 # 相當于num = num * 10
>>> print(num)
40
# 不過python不支持num++ 和num--等,++num就是num,--num也相當于num
>>> 'asdf'[0]
'a'
>>> 'asdf'*3
'asdfasdfasdf'
>>> 'asdf'[1 : 3]
'sd'
>>> 'asdf'[1:]
'sdf'
>>> 'asdf'[:3]
'asd'
>>> 'asdf'[:]
'asdf'
>>> 'asdf'[-1:]
'f'
>>> 'asdf'[:-3]
'a'
# 列表是有序的,元組是有序的
>>> aList = [1, 'a', 2, 'b', 3, 'c'] # 列表切片還是列表
>>> aList[1:5]
['a', 2, 'b', 3]
>>> aTuple = (1, 'a', 2, 'b', 3, 'c') # 元組切片還是元組
>>> aTuple[1:5]
('a', 2, 'b', 3)
# 元素是無序的
>>> aDict = {'aaa':'bbb'}
>>> aDict['111'] = 333
>>> aDict
{'111': 333, 'aaa': 'bbb'}
>>> aDict['222'] = 444
>>> aDict
{'111': 333, '222': 444, 'aaa': 'bbb'}
>>> aDict.keys()
dict_keys(['111', '222', 'aaa'])
>>> aDict['111']
333
>>> for key in aDict:
... print('key = ',key,'valse = ',aDict[key])
...
key = 111 valse = 333
key = 222 valse = 444
key = aaa valse = bbb
# if語句
>>> if 1 > 2:
... print('1')
... elif 2 > 3:
... print('2')
... else:
... print('3')
...
3
# while語句
>>> while x < 3:
... print(x)
... x += 1
...
0
1
2
# for循環和range()內建函數
>>> foo = 'abcde' # 遍歷字符串中的字符
>>> for i in range(len(foo)):
... print(foo[i],'%d'%i)
...
a 0
b 1
c 2
d 3
遍歷key,char的簡易用法
>>> for i ,ch in enumerate(foo):
... print(ch,i)
...
a 0
b 1
c 2
d 3
e 4
# 列表解析
>>> squared = [x ** 2 for x in range(4)]
>>> for i in squared:
... print(i)
...
0
1
4
9
# 后邊還可以進行篩選循環之后的結果后,進行最后解析
>>> squared = [x ** 2 for x in range(4) if not x % 2] # 0是False,1是True
>>> for i in squared:
... print(i)
...
0
4
異常的捕捉
import sys
try:
raiseexcept Exception as e:
t,v,tb = sys.exc_info() # 異常的類型名稱,異常實例,追溯異常流程對象traceback
print(t,v,tb)
文件和內建函數open()和file()
fileName = '.gitignore'
file = open(fileName, 'r')
try:
for line in file: # 最快的讀取每一行文本的方法
# lineline = line.rstrip('\n') # 去除每行末尾的\n符號
lineline = line.rstrip() # 去除\n和空白符
print(lineline)
file.close()
except Exception as e: # python3要求我們的異常必須繼承Exception類,這樣可以捕獲所有異常
print(e)
print('-'*20)
file = open(fileName)
try:
splitlines = file.readlines() # 將所有行一次讀出來
# splitlines = file.read().splitlines() # 將\n給去除
splitlines = file.read().split('\n') # 另一種方法去除
file.close()
for line in splitlines:
print(line,end='')
except Exception as e: # python3要求我們的異常必須繼承Exception類,這樣可以捕獲所有異常
print(e)