命令行輸入
x = input("Please input x:")
y = raw_input("Please input x:")
使用input
和raw_input
都可以讀取控制台的輸入,但是input和raw_input在處理數字時是有區別的。raw_input()
將所有輸入作為字符串看待,返回字符串類型;而 input()
在對待純數字輸入時具有自己的特性,它返回所輸入的數字的類型(int, float),input()
可接受合法的 python 表達式。
看python input的文檔,可以看到input()
本質上還是使用 raw_input()
來實現的,只是調用完 raw_input()
之后再調用 eval()
函數,所以,你甚至可以將表達式作為 input()
的參數,並且它會計算表達式的值並返回它。
def input(prompt):
return (eval(raw_input(prompt)))
除非對 input()
有特別需要,否則一般情況下我們都是推薦使用 raw_input()
來與用戶交互。
輸出
Python兩種輸出值的方式: 表達式語句和 print()
函數。(第三種方式是使用文件對象的 write()
方法; 標准輸出文件可以用 sys.stdout
引用。)
示例:
print "Hello, Python!";
print ("Hello, Python!"); #新版本的Python
輸出的 print 函數總結:
- 字符串和數值類型
可以直接輸出:
>>> print(1)
1
>>> print("Hello World")
Hello World
2.變量
無論什么類型,數值,布爾,列表,字典...都可以直接輸出
>>> x = 12
>>> print(x)
12
>>> s = 'Hello'
>>> print(s)
Hello
>>> L = [1,2,'a']
>>> print(L)
[1, 2, 'a']
>>> t = (1,2,'a')
>>> print(t)
(1, 2, 'a')
>>> d = {'a':1, 'b':2}
>>> print(d)
{'a': 1, 'b': 2}
3.格式化輸出
類似於C中的 printf
>>> s
'Hello'
>>> x = len(s)
>>> print("The length of %s is %d" % (s,x))
The length of Hello is 5
Python中格式化輸出的總結:
(1) %
字符:標記轉換說明符的開始
(2) 轉換標志:-
表示左對齊;+
表示在轉換值之前要加上正負號;""(空白字符)
表示正數之前保留空格;0
表示轉換值若位數不夠則用0填充。示例:
# 指定占位符寬度(左對齊)
>>> print ("Name:%-10s Age:%-8d Height:%-8.2f"%("Aviad",25,1.83))
Name:Aviad Age:25 Height:1.83
# 指定占位符(若位數不夠則用0填充)
>>> print ("Name:%-10s Age:%08d Height:%08.2f"%("Aviad",25,1.83))
Name:Aviad Age:00000025 Height:00001.83
(3) 最小字段寬度:轉換后的字符串至少應該具有該值指定的寬度。如果是*,則寬度會從值元組中讀出。
# 指定占位符寬度
>>> print ("Name:%10s Age:%8d Height:%8.2f"%("Aviad",25,1.83))
Name: Aviad Age: 25 Height: 1.83
(4) 點(.)后跟精度值:如果轉換的是實數,精度值就表示出現在小數點后的位數。如果轉換的是字符串,那么該數字就表示最大字段寬度。如果是*,則從后面的元組中讀取字段寬度或精度。
>>> print ("His height is %f m"%(1.83))
His height is 1.830000 m
>>> print ("His height is %.2f m"%(1.83))
His height is 1.83 m
>>> print ("The String is %.2s"%("abcd"))
The String is ab
# 用*從后面的元組中讀取字段寬度或精度,第1個參數是精度
>>> print ("His height is %.*f m"%(2,1.83))
His height is 1.83 m
(5) 字符串格式化轉換類型
轉換類型 含義
d,i 帶符號的十進制整數
o 不帶符號的八進制
u 不帶符號的十進制
x 不帶符號的十六進制(小寫)
X 不帶符號的十六進制(大寫)
e 科學計數法表示的浮點數(小寫)
E 科學計數法表示的浮點數(大寫)
f,F 十進制浮點數
g 如果指數大於-4或者小於精度值則和e相同,其他情況和f相同
G 如果指數大於-4或者小於精度值則和E相同,其他情況和F相同
C 單字符(接受整數或者單字符字符串)
r 字符串(使用repr轉換任意python對象)
s 字符串(使用str轉換任意python對象)
拼接字符串
a = 'hello '
b = 'world'
>>> a+b
'hello world'
查看變量類型
>>> type(a)
<type 'str'>
部分函數
math開頭需要import math
。
str(object) 把值轉換為字符串
repr(object) 返回值的字符串標示形式
abs(number) 返回數字的絕對值
cmath.sqrt(number) 返回平方根,也可以應用於負數
float(object) 把字符串和數字轉換為浮點數
help() 提供交互式幫助
input(prompt) 獲取用戶輸入
int(object) 把字符串和數字轉換為整數
math.ceil(number) 返回數的上入整數,返回值的類型為浮點數
math.floor(number) 返回數的下舍整數,返回值的類型為浮點數
math.sqrt(number) 返回平方根不適用於負數
pow(x,y[.z]) 返回X的y次冪(有z則對z取模)
round(number[.ndigits]) 根據給定的精度對數字進行四舍五入
str.format() 的基本使用如下:
>>> print('We are the {} who say "{}!"'.format('knights', 'Ni'))
We are the knights who say "Ni!"
括號及其里面的字符 (稱作格式化字段) 將會被 format() 中的參數替換。
自定義打印對象函數:
def prn_obj(obj):
print ', '.join(['%s:%s' % item for item in obj.__dict__.items()])
JSON轉換
json類里提供
json.dumps(param) #list轉json
json.loads(param) #json轉list
示例:
>>> import json
>>> json.dumps(['math','english'])
'["math", "english"]'
>>> json.loads('["math", "english"]')
[u'math', u'english']
json主要用在PHP的array對象 和 python的list對象上。
PHP和Python3能將同樣的json還原成 各自的object 且 在各自的語言環境下代表的意義是同樣的。
但是 PHP和python將object生成json的時候,卻不太一樣了,PHP生成的json中多了反斜線。
打開文件
#!/usr/bin/python
# -*- coding: UTF-8 -*-
# 打開文件
fo = open("runoob.txt", "r+")
print "文件名為: ", fo.name
line = fo.read(10)
print "讀取的字符串: %s" % (line)
# 關閉文件
fo.close()
運算符
Python支持:
- 算數運算符
- 關系運算符
- 賦值運算符
- 邏輯運算符
- 位運算符
除了以上的一些運算符之外,Python還支持成員運算符,身份運算符:
- 成員運算符
- 身份運算符
算術運算符
以下假設變量a為10,變量b為20:
運算符 | 描述 | 實例 |
---|---|---|
+ | 加 - 兩個對象相加 | a + b 輸出結果 30 |
- | 減 - 得到負數或是一個數減去另一個數 | a - b 輸出結果 -10 |
* | 乘 - 兩個數相乘或是返回一個被重復若干次的字符串 | a * b 輸出結果 200 |
/ | 除 - x除以y | b / a 輸出結果 2 |
% | 取模 - 返回除法的余數 | b % a 輸出結果 0 |
** | 冪 - 返回x的y次冪 | a**b 為10的20次方, 輸出結果 100000000000000000000 |
// | 取整除 - 返回商的整數部分 | 9//2 輸出結果 4 , 9.0//2.0 輸出結果 4.0 |
Python算術運算符沒有C語言里的自增(++
)自減(--
)運算符。
關系運算符
以下假設變量a為10,變量b為20:
運算符 | 描述 | 實例 |
---|---|---|
== | 等於 - 比較對象是否相等 | (a == b) 返回 False。 |
!= | 不等於 - 比較兩個對象是否不相等 | (a != b) 返回 true. |
<> | 不等於 - 比較兩個對象是否不相等 | (a <> b) 返回 true。這個運算符類似 != 。 |
> | 大於 - 返回x是否大於y | (a > b) 返回 False。 |
< | 小於 - 返回x是否小於y。所有比較運算符返回1表示真,返回0表示假。這分別與特殊的變量True和False等價。注意,這些變量名的大寫。 | (a < b) 返回 true。 |
>= |
大於等於 - 返回x是否大於等於y。 | (a >= b) 返回 False。 |
<= | 小於等於 - 返回x是否小於等於y。 | (a <= b) 返回 true。 |
賦值運算符
以下假設變量a為10,變量b為20:
運算符 | 描述 | 實例 |
---|---|---|
= | 簡單的賦值運算符 | c = a + b 將 a + b 的運算結果賦值為 c |
+= | 加法賦值運算符 | c += a 等效於 c = c + a |
-= | 減法賦值運算符 | c -= a 等效於 c = c - a |
*= | 乘法賦值運算符 | c *= a 等效於 c = c * a |
/= | 除法賦值運算符 | c /= a 等效於 c = c / a |
%= | 取模賦值運算符 | c %= a 等效於 c = c % a |
**= | 冪賦值運算符 | c **= a 等效於 c = c ** a |
//= | 取整除賦值運算符 | c //= a 等效於 c = c // a |
邏輯運算符
Python語言支持邏輯運算符。
在Python中是沒有&&
、||
、!
這三個運算符的,取而代之的是英文and
、or
、not
。
以下假設變量 a 為 10, b為 20:
運算符 | 邏輯表達式 | 描述 | 實例 |
---|---|---|---|
and | x and y | 布爾"與" - 如果 x 為 False,x and y 返回 False,否則它返回 y 的計算值。 | (a and b) 返回 20 |
or | x or y | 布爾"或" - 如果 x 是非 0,它返回 x 的值,否則它返回 y 的計算值。 | (a or b) 返回 10。 |
not | not x | 布爾"非" - 如果 x 為 True,返回 False 。如果 x 為 False,它返回 True。 | not(a and b) 返回 False |
位運算符
按位運算符是把數字看作二進制來進行計算的。Python中的按位運算法則如下:
下表中變量 a 為 60,b 為 13,二進制格式如下:
a = 0011 1100
b = 0000 1101
-----------------
a&b = 0000 1100
a|b = 0011 1101
a^b = 0011 0001
~a = 1100 0011
運算符 | 描述 | 實例 |
---|---|---|
& | 按位與運算符:參與運算的兩個值,如果兩個相應位都為1,則該位的結果為1,否則為0 | (a & b) 輸出結果 12 ,二進制解釋: 0000 1100 |
| |
按位或運算符:只要對應的二個二進位有一個為1時,結果位就為1。 | (a | b) 輸出結果 61 ,二進制解釋: 0011 1101 |
^ | 按位異或運算符:當兩對應的二進位相異時,結果為1 | (a ^ b) 輸出結果 49 ,二進制解釋: 0011 0001 |
~ |
按位取反運算符:對數據的每個二進制位取反,即把1變為0,把0變為1 | (~a ) 輸出結果 -61 ,二進制解釋: 1100 0011, 在一個有符號二進制數的補碼形式。 |
<< |
左移動運算符:運算數的各二進位全部左移若干位,由"<<"右邊的數指定移動的位數,高位丟棄,低位補0。 | a << 2 輸出結果 240 ,二進制解釋: 1111 0000 |
>> |
右移動運算符:把">>"左邊的運算數的各二進位全部右移若干位,">>"右邊的數指定移動的位數 | a >> 2 輸出結果 15 ,二進制解釋: 0000 1111 |
成員運算符
以下假設變量 a 為 1, b為 20,c為[1, 2, 3, 4, 5 ]
:
運算符 | 描述 | 實例 |
---|---|---|
in | 如果在指定的序列中找到值返回 True,否則返回 False。 | (a in c) , 返回 True。 |
not in | 如果在指定的序列中沒有找到值返回 True,否則返回 False。 | (b not in c) , 返回 True。 |
身份運算符
身份運算符用於比較兩個對象的存儲單元。
運算符 | 描述 | 實例 |
---|---|---|
is | is是判斷兩個標識符是不是引用自一個對象 | x is y, 如果 id(x) 等於 id(y) , is 返回結果 1 |
is not | is not是判斷兩個標識符是不是引用自不同對象 | x is not y, 如果 id(x) 不等於 id(y). is not 返回結果 1 |
運算符優先級
運算符 | 描述 |
---|---|
** | 指數 (最高優先級) |
~ + - |
按位翻轉, 一元加號和減號 (最后兩個的方法名為 +@ 和 -@) |
* / % // |
乘,除,取模和取整除 |
+ - |
加法減法 |
>> << |
右移,左移運算符 |
& | 位 'AND' |
^ | |
位運算符 |
<= < > >= | 比較運算符 |
<> == != | 等於運算符 |
= %= /= //= -= += *= **= |
賦值運算符 |
is is not | 身份運算符 |
in not in | 成員運算符 |
not or and | 邏輯運算符 |
參考:
1、Python 3 語法小記(一)入門 (print 函數用法總結) - Just Coding! - 博客頻道 - CSDN.NET
http://blog.csdn.net/jcjc918/article/details/9354815
2、Python格式化輸出 - MindProbe - 博客園
http://www.cnblogs.com/plwang1990/p/3757549.html
3、Python3 的json 和 PHP的json - 寧靜的天空 - 博客園
http://www.cnblogs.com/ribavnu/p/4850413.html