Python學習--02輸入和輸出、運算符


命令行輸入

x = input("Please input x:") 
y = raw_input("Please input x:") 

使用inputraw_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

示例:

print "Hello, Python!";
print ("Hello, Python!"); #新版本的Python

輸出的 print 函數總結:

  1. 字符串和數值類型
    可以直接輸出:
>>> 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中是沒有&&||!這三個運算符的,取而代之的是英文andornot

以下假設變量 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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM