真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Python運(yùn)算符和函數(shù),python的或運(yùn)算符

python // 與 / * 和 ** 運(yùn)算符 的含義

1 在 Python 2.2 :

創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比江干網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式江干網(wǎng)站制作公司更省心,省錢(qián),快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋江干地區(qū)。費(fèi)用合理售后完善,十年實(shí)體公司更值得信賴。

? ? 要引用: from __future__ import division

" / "就表示 浮點(diǎn)數(shù)除法,返回浮點(diǎn)結(jié)果;" // "表示整數(shù)除法。

2? ? Python 3以后? :

" / "就表示 浮點(diǎn)數(shù)除法,返回浮點(diǎn)結(jié)果;" // "表示整數(shù)除法。

python? //10 除以10 然后向下取整

在 Python 中,* 和 ** 具有語(yǔ)法多義性,具體來(lái)說(shuō)是有四類用法。

1. 算數(shù)運(yùn)算

* ?代表乘法

** 代表乘方

2*5

10

2**5

32

2. 函數(shù)形參

*args 和 **kwargs 主要用于函數(shù)定義。

你可以將不定數(shù)量的參數(shù)傳遞給一個(gè)函數(shù)。不定的意思是:預(yù)先并不知道, 函數(shù)使用者會(huì)傳遞多少個(gè)參數(shù)給你, 所以在這個(gè)場(chǎng)景下使用這兩個(gè)關(guān)鍵字。其實(shí)并不是必須寫(xiě)成 *args 和 **kwargs。 ?*(星號(hào)) 才是必須的. 你也可以寫(xiě)成 *ar ?和 **k 。而寫(xiě)成 *args 和**kwargs 只是一個(gè)通俗的命名約定。

python函數(shù)傳遞參數(shù)的方式有兩種:

位置參數(shù)(positional argument)

關(guān)鍵詞參數(shù)(keyword argument)

*args 與 **kwargs 的區(qū)別,兩者都是 python 中的可變參數(shù):

*args 表示任何多個(gè)無(wú)名參數(shù),它本質(zhì)是一個(gè) tuple

**kwargs 表示關(guān)鍵字參數(shù),它本質(zhì)上是一個(gè) dict

如果同時(shí)使用 *args 和 **kwargs 時(shí),必須 *args 參數(shù)列要在 **kwargs 之前。

deffun(*args, **kwargs):

... print('args=', args)

... print('kwargs=', kwargs)

...

fun(1,2,3,4, A='a', B='b', C='c', D='d')

args= (1,2,3,4)

kwargs= {'A':'a','B':'b','C':'c','D':'d'}

使用 *args

deffun(name, *args):

... print('你好:', name)

... foriinargs:

... print("你的寵物有:", i)

...

fun("Geek","dog","cat")

你好: Geek

你的寵物有: dog

你的寵物有: cat

使用?**kwargs

deffun(**kwargs):

... forkey, valueinkwargs.items():

... print("{0} 喜歡 {1}".format(key, value))

...

fun(Geek="cat", cat="box")

Geek 喜歡 cat

cat 喜歡 box

3. 函數(shù)實(shí)參

如果函數(shù)的形參是定長(zhǎng)參數(shù),也可以使用 *args 和 **kwargs 調(diào)用函數(shù),類似對(duì)元組和字典進(jìn)行解引用:

deffun(data1, data2, data3):

... print("data1: ", data1)

... print("data2: ", data2)

... print("data3: ", data3)

...

args = ("one",2,3)

fun(*args)

data1:? one

data2:2

data3:3

kwargs = {"data3":"one","data2":2,"data1":3}

fun(**kwargs)

data1:3

data2:2

data3:? one

4. 序列解包

a, b, *c =0,1,2,3

a

b

1

c

[2,3]

享學(xué)課堂淺談Python序列內(nèi)建函數(shù)都有哪些

1、Python類型操作符和內(nèi)建函數(shù)總結(jié)

表4.5列出了所有操作符和內(nèi)建函數(shù),其中操作符順序是按優(yōu)先級(jí)從高到低排列的。同一種灰度的操作符擁有同樣的優(yōu)先級(jí)。注意在operator模塊中有這些(和絕大多數(shù)Python)操作符相應(yīng)的同功能的函數(shù)可供使用。

表4.5 標(biāo)準(zhǔn)類型操作符和內(nèi)建函數(shù)

操作符/函數(shù)

描 述

結(jié) 果a

字符串表示

``

對(duì)象的字符串表示

str

內(nèi)建函數(shù)

cmp(obj1, obj2)

比較兩個(gè)對(duì)象

int

repr(obj)

對(duì)象的字符串表示

str

str(obj)

對(duì)象的字符串表示

str

type(obj)

檢測(cè)對(duì)象的類型

type

值比較

小于

bool

大于

bool

=

小于或等于

bool

=

大于或等于

bool

==

等于

bool

!=

不等于

bool

不等于

bool

對(duì)象比較

is

bool

is not

不是

bool

布爾操作符

not

邏輯反

bool

and

邏輯與

bool

or

邏輯或

bool

2、Python數(shù)值類型操作符和內(nèi)建函數(shù)

一、工廠函數(shù)

數(shù)值工廠函數(shù)總結(jié)類(工廠函數(shù)) 操作

bool(obj) b 返回obj對(duì)象的布爾值,也就是 obj.__nonzero__()方法的返回值。

int(obj, base=10)   返回一個(gè)字符串或數(shù)值對(duì)象的整數(shù)表 示, 類似string.atoi();

從Python 1.6起, 引入了可選的進(jìn)制參數(shù)。

long(obj, base=10) 返回一個(gè)字符或數(shù)據(jù)對(duì)象的長(zhǎng)整數(shù)表 示,類似string.atol(),

從Python1.6起, 引入了可選的進(jìn)制參數(shù) float(obj) ,

返回一個(gè)字符串或數(shù)據(jù)對(duì)象的浮點(diǎn)數(shù) 表示,類似string.atof()。

complex(str) or返回一個(gè)字符串的復(fù)數(shù)表示,或 者根據(jù)給定的實(shí)數(shù),

complex(real, imag=0.0)  (及一個(gè)可選 的虛數(shù)部分)生成一個(gè)復(fù)數(shù)對(duì)象。

二、內(nèi)建函數(shù)

1、分類

Python 有五個(gè)運(yùn)算內(nèi)建函數(shù)用于數(shù)值運(yùn)算:

abs(num), coerce(num1,num2), divmod(num1,num2), pow(num1,num2,mod=1)和 round(flt,ndig=0)

其中abs()返回給定參數(shù)的絕對(duì)值。如果參數(shù)是一個(gè)復(fù)數(shù), 那么就返回math.sqrt(num.real2 + num.imag2).

coerce()是一個(gè)數(shù)據(jù)類型轉(zhuǎn)換函數(shù),不過(guò)它的行為更像一個(gè)運(yùn)算符.數(shù)coerce()為程序員提供了不依賴Python 解釋器,而是自定義兩個(gè)數(shù)值類型轉(zhuǎn)換的方法。對(duì)一種新創(chuàng)建的數(shù)值類型來(lái)說(shuō), 這個(gè)特性非常有用.函數(shù)coerce()僅返回一個(gè)包含類型轉(zhuǎn)換完畢的兩個(gè)數(shù)值元素的元組.

divmod()內(nèi)建函數(shù)把除法和取余運(yùn)算結(jié)合起來(lái), 返回一個(gè)包含商和余數(shù)的元組.對(duì)整數(shù)來(lái)說(shuō),它的返回值就是地板除和取余操作的結(jié)果.對(duì)浮點(diǎn)數(shù)來(lái)說(shuō),返回的商部分是math.floor(num1/num2),對(duì)復(fù)數(shù)來(lái)說(shuō),商部分是ath.floor((num1/num2).real).

pow()它和雙星號(hào) (**)運(yùn)算符都可以進(jìn)行指數(shù)運(yùn)算.不過(guò)二者的區(qū)別并不僅僅在于一個(gè)是運(yùn)算符,一個(gè)是內(nèi)建函數(shù).在Python 1.5 之前,并沒(méi)有 ** 運(yùn)算符,內(nèi)建函數(shù)pow()還接受第三個(gè)可選的參數(shù),一個(gè)余數(shù)參數(shù).如果有這個(gè)參數(shù)的, pow() 先進(jìn)行指數(shù)運(yùn)算,然后將運(yùn)算結(jié)果和第三個(gè)參數(shù)進(jìn)行取余運(yùn)算.這個(gè)特性主要用于密碼運(yùn)算,并且比 pow(x,y) % z 性能更好, 這是因?yàn)檫@個(gè)函數(shù)的實(shí)現(xiàn)類似于C 函數(shù)pow(x,y,z).

round()用于對(duì)浮點(diǎn)數(shù)進(jìn)行四舍五入運(yùn)算。它有一個(gè)可選的小數(shù)位數(shù)參數(shù).如果不提供小數(shù)位參數(shù), 它返回與第一個(gè)參數(shù)最接近的整數(shù)(但仍然是浮點(diǎn)類型).第二個(gè)參數(shù)告訴round 函數(shù)將結(jié)果精確到小數(shù)點(diǎn)后指定位數(shù).

2、函數(shù)int()/round()/math.floor()它們之間的不同之處:

函數(shù) int()直接截去小數(shù)部分.(返回值為整數(shù))

函數(shù) floor() 得到最接近原數(shù)但小于原數(shù)的整數(shù).(返回值為浮點(diǎn)數(shù))

函數(shù) round() 得到最接近原數(shù)的整數(shù).(返回值為浮點(diǎn)數(shù))

3、進(jìn)制轉(zhuǎn)換函數(shù):

返回字符串表示的8 進(jìn)制和16 進(jìn)制整數(shù),它們分別是內(nèi)建函數(shù):

oct()和 hex(). oct(255)='0377'/hex(255)='0xff'

函數(shù)chr()接受一個(gè)單字節(jié)整數(shù)值(0到255),返回一個(gè)字符串(ASCII),其值為對(duì)應(yīng)的字符.chr(97)='a'

函數(shù)ord()則相反,它接受一個(gè)字符(ASCII 或 Unicode),返回其對(duì)應(yīng)的整數(shù)值.ord('A')=65

3、Python字符串函數(shù)

(一)標(biāo)準(zhǔn)類型操作符和標(biāo)準(zhǔn)內(nèi)建函數(shù)

1)、標(biāo)準(zhǔn)類型操作符

,,=,=,==,!=,對(duì)象值得比較

注:做比較時(shí)字符串是按ASCII值的大小來(lái)比較的

is 對(duì)象身份比較

and,or,not 布爾類型

2)標(biāo)準(zhǔn)內(nèi)建函數(shù)

type(obj)

cmp(obj1,obj2)

str(obj)和repr(obj) 或反引號(hào)運(yùn)算符(``) 可以方便的以字符串的方式獲取對(duì)象的

內(nèi)容、類型、數(shù)值屬性等信息。str()函數(shù)得到的字符串可讀性好, 而repr()函數(shù)得到的字符

串通??梢杂脕?lái)重新獲得該對(duì)象, 通常情況下 obj == eval(repr(obj)) 這個(gè)等式是成立的

isinstance(obj,type) 判斷對(duì)象的類型

(二)序列操作

1、序列操作

字符串屬于序列對(duì)象,可以使用所有序列的操作和函數(shù)

切片 [] [:] [::]

簡(jiǎn)單總結(jié):

*索引(S[i])獲取特定偏移的元素。

——第一個(gè)元素偏移為0

——(S[0])獲取第一個(gè)元素。

——負(fù)偏移索引意味著從最后或右邊反向進(jìn)行計(jì)數(shù)

——(S[-2])獲取倒數(shù)第二個(gè)元素(就像S[len(s)-2]一樣

*分片[S[i:j]提取對(duì)應(yīng)的部分作為一個(gè)序列

——右邊界不包含在內(nèi)

——分片的邊界默認(rèn)為0和序列的長(zhǎng)度,如果沒(méi)有給出的話S[:]

——(S[1:3])獲取了從偏移為1,直到但不包括偏移為3的元素

——(S[1:])獲取從偏移為1到末尾之間的元素

——(S[:3])獲取從偏移為0直到但不包括偏移為3的元素

——(S[:-1])獲取從偏移為0直到但不包括最后一個(gè)元素之間的元素

——(S[:])獲取從偏移為0到末尾之間的元素,這有效地實(shí)現(xiàn)了頂層S拷貝

拷貝了一個(gè)相同值,但是是不同內(nèi)存區(qū)域的對(duì)象。對(duì)象字符串這樣不可變的對(duì)象不是很有用,但是對(duì)于可以實(shí)地修改的對(duì)象來(lái)說(shuō)很有用。

比如列表。

擴(kuò)展分片:第三個(gè)限制值 【步進(jìn)】

完整形式:X[I:J:K]:這標(biāo)識(shí)索引X對(duì)象的元素,從偏移為I直到J-1,每隔K元素索引一次。第三個(gè)限制值,K,默認(rèn)為1

實(shí)例

Python Code

1

2

3

4

5

S='abcdefghijk'

S[1:10]

'bcdefghij'

S[1:10:2]

'bdfhj

也可以使用負(fù)數(shù)作為步進(jìn)。

分片表達(dá)式

Python Code

1

2

"hello"[::-1]

'olleh'

通過(guò)負(fù)數(shù)步進(jìn),兩個(gè)邊界的意義實(shí)際上進(jìn)行了反轉(zhuǎn)。

3、成員操作符 in ,not in

返回布爾值True 或False

可以使用string模塊來(lái)判斷輸入字符的合法性,可見(jiàn)成品中的idcheck.py

4、字符串連接

+ 連接字符串 ‘name’+' '+'jin'

字符串格式化 '%s %s' % ('name','jin')

join()方法 ' '.join(('name','jin')) ' '.join(['name','jin'])

5、刪除清空字符串

del aString

aString=''

(三)、序列函數(shù)

序列類型函數(shù)

len(str) 返回字串的長(zhǎng)度

enumerate(iter):接受一個(gè)可迭代對(duì)象作為參數(shù),返回一個(gè)enumerate

max(str)/min(str):max()和min()函數(shù)對(duì)其他的序列類型可能更有用,但對(duì)于string類型它們能很好地運(yùn)行,返回最大或者最小的字符(按照ASCII 碼值排列),

zip([it0, it1,... itN]) 返回一個(gè)列表,其第一個(gè)元素是it0,it1,...這些元素的第一個(gè)元素組成的一個(gè)元組,第二個(gè)...,類推.

reversed(seq)c 接受一個(gè)序列作為參數(shù),返回一個(gè)以逆序訪問(wèn)的迭代器(PEP 322)

sorted(iter,func=None,key=None,reverse=False) 接受一個(gè)可迭代對(duì)象作為參數(shù),返回一個(gè)有序的列表;可選參數(shù)func,key 和reverse 的含義跟list.sort()內(nèi)建函數(shù)的參數(shù)含義一樣.

注意:

sorted等需要在原處修改的函數(shù)無(wú)法用在字符串對(duì)象,但可以產(chǎn)生新的對(duì)象

sum處理的對(duì)象是數(shù)字,不能用在字符串

sorted(s)

['a', 'e', 'e', 'g', 'g', 'g', 'o']

(四)只適合于字符串類型的函數(shù)

1)raw_input()函數(shù)

內(nèi)建的raw_input()函數(shù)使用給定字符串提示用戶輸入并將這個(gè)輸入返回,下面是一個(gè)使

用raw_input()的例子:

user_input = raw_input("Enter your name: ")

prin user_input

2)str() and unicode()

str()和unicode()函數(shù)都是工廠函數(shù),就是說(shuō)產(chǎn)生所對(duì)應(yīng)的類型的對(duì)象.它們接受一個(gè)任

意類型的對(duì)象,然后創(chuàng)建該對(duì)象的可打印的或者Unicode 的字符串表示. 它們和basestring 都

可以作為參數(shù)傳給isinstance()函數(shù)來(lái)判斷一個(gè)對(duì)象的類型

3)chr(), unichr(), and ord()

chr()函數(shù)用一個(gè)范圍在range(256)內(nèi)的(就是0 到255)整數(shù)做參數(shù),返回一個(gè)對(duì)應(yīng)的字符.unichr()跟它一樣,只不過(guò)返回的是Unicode 字符

ord()函數(shù)是chr()函數(shù)(對(duì)于8 位的ASCII 字符串)或unichr()函數(shù)(對(duì)于Unicode 對(duì)象)

的配對(duì)函數(shù),它以一個(gè)字符(長(zhǎng)度為1 的字符串)作為參數(shù),返回對(duì)應(yīng)的ASCII 數(shù)值,或者Unicode

數(shù)值,如果所給的Unicode 字符超出了你的Python 定義范圍,則會(huì)引發(fā)一個(gè)TypeError 的異常

(五)、只適用于字符串的操作符

1、格式化操作符 %

字符串格式化符號(hào)

格式化字符 轉(zhuǎn)換方式

%c 轉(zhuǎn)換成字符(ASCII 碼值,或者長(zhǎng)度為一的字符串)

%ra 優(yōu)先用repr()函數(shù)進(jìn)行字符串轉(zhuǎn)換

%s 優(yōu)先用str()函數(shù)進(jìn)行字符串轉(zhuǎn)換

%d / %i 轉(zhuǎn)成有符號(hào)十進(jìn)制數(shù)

%ub 轉(zhuǎn)成無(wú)符號(hào)十進(jìn)制數(shù)

%ob 轉(zhuǎn)成無(wú)符號(hào)八進(jìn)制數(shù)

%xb/%Xb (Unsigned)轉(zhuǎn)成無(wú)符號(hào)十六進(jìn)制數(shù)(x/X 代表轉(zhuǎn)換后的十六進(jìn)制字符的大

小寫(xiě))

%e/%E 轉(zhuǎn)成科學(xué)計(jì)數(shù)法(e/E 控制輸出e/E)

%f/%F 轉(zhuǎn)成浮點(diǎn)數(shù)(小數(shù)部分自然截?cái)?

%g/%G %e 和%f/%E 和%F 的簡(jiǎn)寫(xiě)

%% 輸出%

格式化操作符輔助指令

符號(hào) 作用

* 定義寬度或者小數(shù)點(diǎn)精度

- 用做左對(duì)齊

+ 在正數(shù)前面顯示加號(hào)( + )

sp 在正數(shù)前面顯示空格

# 在八進(jìn)制數(shù)前面顯示零('0'),在十六進(jìn)制前面顯示'0x'或者'0X'(取決于

用的是'x'還是'X')

0 顯示的數(shù)字前面填充‘0’而不是默認(rèn)的空格

% '%%'輸出一個(gè)單一的'%'

(var) 映射變量(字典參數(shù))

m.n m 是顯示的最小總寬度,n 是小數(shù)點(diǎn)后的位數(shù)(如果可用的話)

2、字符串模板: 更簡(jiǎn)單的替代品

由于新式的字符串Template 對(duì)象的引進(jìn)使得string 模塊又重新活了過(guò)來(lái),Template 對(duì)象

有兩個(gè)方法,substitute()和safe_substitute().前者更為嚴(yán)謹(jǐn),在key 缺少的情況下它會(huì)報(bào)一

個(gè)KeyError 的異常出來(lái),而后者在缺少key 時(shí),直接原封不動(dòng)的把字符串顯示出

3、原始字符串操作符( r/R )

字符串抑制轉(zhuǎn)義r'帶特殊符號(hào)的字串'

myfile=open(r'C:\new\text.data','w')

4、Unicode 字符串操作符( u/U )

u'abc' U+0061 U+0062 U+0063

u'\u1234' U+1234

u'abc\u1234\n' U+0061 U+0062 U+0063 U+1234 U+0012

(六)字符串對(duì)象的方法:

1、刪減

T2.lstrip() 移除字符串前面字符(默認(rèn)空格),返回字符串

T2.rstrip() 移除字符串后面字符(默認(rèn)空格),返回字符串

T2.strip() 移除字符串前后面空格,返回字符串 默認(rèn)空格,可以其他字符 S.strip('"')

2、切割

partition(sep),

rpartition(sep),

splitlines([keepends]),#把S按照行分割符分為一個(gè)list,keepends是一個(gè)bool值,如果為真每行后而會(huì)保留行分割符

split([sep [,maxsplit]]),#以sep為分隔符,把S分成一個(gè)list。maxsplit表示分割的次數(shù)。默認(rèn)的分割符為空白字符

rsplit([sep[,maxsplit]]) #從右到左切割

備注:

partition()函數(shù)族是2.5版本新增的方法。它接受一個(gè)字符串參數(shù),并返回一個(gè)3個(gè)元素的 tuple 對(duì)象。

如果sep沒(méi)出現(xiàn)在母串中,返回值是 (sep, ‘’, ‘’);

否則,返回值的第一個(gè)元素是 sep 左端的部分,第二個(gè)元素是 sep 自身,第三個(gè)元素是 sep 右端的部分。

S.partition(';')

('', ';', ' generated by /sbin/dhclient-script\nnameserver 172.16.10.171\nnameserver 8.8.8.8\nnameserver 172.16.0.2\nnameserver 178.79.131.110\nnameserver 202.96.199.133\n')

參數(shù) maxsplit 是分切的次數(shù),即最大的分切次數(shù),所以返回值最多有 maxsplit+1 個(gè)元素。

s.split() 和 s.split(‘ ‘)的返回值不盡相同

' hello world!'.split()

['hello', 'world!']

' hello world!'.split(' ')

['', '', 'hello', '', '', 'world!']

S.split('\n',3)

['; generated by /sbin/dhclient-script', 'nameserver 172.16.10.171', 'nameserver 8.8.8.8', 'nameserver 172.16.0.2\nnameserver 178.79.131.110\nnameserver 202.96.199.133\n']

超過(guò)最大切割個(gè)數(shù)后面的全部為一個(gè)元素

按行切割

S

'; generated by /sbin/dhclient-script\nnameserver 172.16.10.171\nnameserver 8.8.8.8\nnameserver 172.16.0.2\nnameserver 178.79.131.110\nnameserver 202.96.199.133\n'

S.splitlines()

['; generated by /sbin/dhclient-script', 'nameserver 172.16.10.171', 'nameserver 8.8.8.8', 'nameserver 172.16.0.2', 'nameserver 178.79.131.110', 'nameserver 202.96.199.133']

產(chǎn)生差異的原因在于當(dāng)忽略 sep 參數(shù)或sep參數(shù)為 None 時(shí)與明確給 sep 賦予字符串值時(shí) split() 采用兩種不同的算法。

對(duì)于前者,split() 先去除字符串兩端的空白符,然后以任意長(zhǎng)度的空白符串作為界定符分切字符串

即連續(xù)的空白符串被當(dāng)作單一的空白符看待;

對(duì)于后者則認(rèn)為兩個(gè)連續(xù)的 sep 之間存在一個(gè)空字符串。因此對(duì)于空字符串(或空白符串),它們的返回值也是不同的:

''.split()

[]

''.split(' ')

['']

3、變形

lower(),#全部小寫(xiě)

upper(),#全部小寫(xiě)

capitalize(),#首字母大寫(xiě)

swapcase(),#大小寫(xiě)交換

title()#每個(gè)單詞第一個(gè)大寫(xiě),其他小寫(xiě)

備注

因?yàn)閠itle() 函數(shù)并不去除字符串兩端的空白符也不會(huì)把連續(xù)的空白符替換為一個(gè)空格,

所以建議使用string 模塊中的capwords(s)函數(shù),它能夠去除兩端的空白符,再將連續(xù)的空白符用一個(gè)空格代替。

Python Code

1

2

3

4

' hello world!'.title()

' Hello World!'

string.capwords(' hello world!')

'Hello World!'

4、連接

join(seq)

join() 函數(shù)的高效率(相對(duì)于循環(huán)相加而言),使它成為最值得關(guān)注的字符串方法之一。

它的功用是將可迭代的字符串序列連接成一條長(zhǎng)字符串,如:

conf = {'host':'127.0.0.1',

... 'db':'spam',

... 'user':'sa',

... 'passwd':'eggs'}

';'.join("%s=%s"%(k, v) for k, v in conf.iteritems())

'passswd=eggs;db=spam;user=sa;host=127.0.0.1'

S=''.join(T) #使用空字符串分割把字符列表轉(zhuǎn)換為字符串

5、查找

count( sub[, start[, end]]),#計(jì)算substr在S中出現(xiàn)的次數(shù)

find( sub[, start[, end]]),#返回S中出現(xiàn)sub的第一個(gè)字母的標(biāo)號(hào),如果S中沒(méi)有sub則返回-1。start和end作用就相當(dāng)于在S[start:end]中搜索

index( substr[, start[, end]]),#與find()相同,只是在S中沒(méi)有substr時(shí),會(huì)返回一個(gè)運(yùn)行時(shí)錯(cuò)誤

rfind( sub[, start[,end]]),#返回S中最后出現(xiàn)的substr的第一個(gè)字母的標(biāo)號(hào),如果S中沒(méi)有substr則返回-1,也就是說(shuō)從右邊算起的第一次出現(xiàn)的substr的首字母標(biāo)號(hào)

rindex( sub[, start[, end]])

T2.find('ie') 字符串方法調(diào)用:搜索

find()----找到的第一個(gè)符合字符的index

rfind()-----找到最后一個(gè)符合的字符的index

備注:

find()函數(shù)族找不到時(shí)返回-1,index()函數(shù)族則拋出ValueError異常。

另,也可以用 in 和 not in 操作符來(lái)判斷字符串中是否存在某個(gè)模板

6、替換

replace(old, new[,count]),#把S中的oldstar替換為newstr,count為替換次數(shù)。這是替換的通用形式,還有一些函數(shù)進(jìn)行特殊字符的替換

translate(table[,deletechars]) #使用上面的函數(shù)產(chǎn)后的翻譯表,把S進(jìn)行翻譯,并把deletechars中有的字符刪掉

備注:

replace()函數(shù)的 count 參數(shù)用以指定最大替換次數(shù)

translate() 的參數(shù) table 可以由 string.maketrans(frm, to) 生成

translate() 對(duì) unicode 對(duì)象的支持并不完備,建議不要使用

7、判定

isalnum(),#是否全是字母和數(shù)字,并至少有一個(gè)字符

isalpha(),是否全是字母,并至少有一個(gè)字符

isdigit(),是否全是數(shù)字,并至少有一個(gè)字符 ,如果是全數(shù)字返回True,否則返回False

islower(),#S中的字母是否全是小寫(xiě)

isupper(),#S中的字母是否是大寫(xiě)

isspace(),#是否全是空白字符,并至少有一個(gè)字符

istitle(),S是否是首字母大寫(xiě)的

startswith(prefix[, start[, end]]), #是否以prefix開(kāi)頭

endswith(suffix[,start[, end]]),#以suffix結(jié)尾

備注:

這些函數(shù)都比較簡(jiǎn)單,顧名知義。需要注意的是*with()函數(shù)族可以接受可選的 start, end 參數(shù),善加利用,可以優(yōu)化性能。

另,自 Py2.5 版本起,*with() 函數(shù)族的 prefix 參數(shù)可以接受 tuple 類型的實(shí)參,當(dāng)實(shí)參中的某人元素能夠匹配,即返回 True。

8、填充

字符串在輸出時(shí)的對(duì)齊:

center(width[, fillchar]), 字符串中間對(duì)齊

ljust(width[, fillchar]), 字符串左對(duì)齊,不足部分用fillchar填充,默認(rèn)的為空格

rjust(width[, fillchar]), 字符串右對(duì)齊,不足部分用fillchar填充,默認(rèn)的為空格

zfill(width), 把字符串變成width長(zhǎng),并在右對(duì)齊,不足部分用0補(bǔ)足

expandtabs([tabsize])把字符串中的制表符(tab)轉(zhuǎn)換為適當(dāng)數(shù)量的空格。

fillchar 參數(shù)指定了用以填充的字符,默認(rèn)為空格

zfill的z為zero的縮寫(xiě),顧名思義,是以字符0進(jìn)行填充,用于數(shù)值輸出

expandtabs()的tabsize 參數(shù)默認(rèn)為8。它的功能是把字符串中的制表符(tab)轉(zhuǎn)換為適當(dāng)數(shù)量的空格。

9、編碼

encode([encoding[,errors]]),

decode([encoding[,errors]])

這是一對(duì)互逆操作的方法,用以編碼和解碼字符串。因?yàn)閟tr是平臺(tái)相關(guān)的,它使用的內(nèi)碼依賴于操作系統(tǒng)環(huán)境,

而unicode是平臺(tái)無(wú)關(guān)的,是Python內(nèi)部的字符串存儲(chǔ)

python運(yùn)算符

1.*,兩個(gè)數(shù)相乘或返回一個(gè)被重復(fù)多次的字符串

2.**,冪,如a**b,表示返回a的b次方的數(shù)

3.//,取相除的整數(shù)部分

== 是否相等

!= 是否不相等

是否大于

是否小于

= 是否大于等于

= 是否小于等于

注意:比較返回的真(True),假(False),首字母是大寫(xiě)的

(變量1 if(變量1變量2) else 變量2)

如果if里為真,返回變量1,否則返回變量2

= 賦值

+= a+=b --a=a+b,從右往左

-= a-=b -- a=a-b,

*= a*=b -- a=a*b

/= a/=b -- a=a/b

%= a%=b -- a=a%b #取余

**= a**=b -- a=a**b#冪數(shù)

//=a//=b -- a=a//b #取整

位與 都為1,結(jié)果1

| 位或 有1為1

^ 異或 不同為1

~ 非 1為0,0為1,(~a ) 輸出結(jié)果 -61 ,二進(jìn)制解釋: 1100 0011, 在一個(gè)有符號(hào)二進(jìn)制數(shù)的補(bǔ)碼形式。

左移 高丟低補(bǔ)0 左邊為高位,右邊為低位

右移 低丟高補(bǔ)0

#案例:計(jì)算20往左移2位,得到結(jié)果a,20往右移動(dòng)2位,得到結(jié)果b,然后打印出a,b結(jié)果

#然后ab,得到結(jié)果c,打印c的結(jié)果.要寫(xiě)出計(jì)算過(guò)程

#0001 0100

#0101 0000

a=202

#0001 0100

#0000 0101

b=202

print(a)

print(b)

#0101 0000

#0000 0101

#0000 0000

c=ab

print(c)

and 邏輯與 有假為假

or 邏輯或? 有真為真

not 邏輯非 真變假,假變真

例如:

a=True

b=False

print(a and b)返回false

print(a or b)返回true

print(not a)返回false

in 如果在指定的序列中找到了值,那么返回True

not in 如果在指定的序列中沒(méi)有找到了值,那么返回True

#案例:判斷'dfsafaqianfengdfasfafd,該字符串中有沒(méi)有huawei

mystr='dfsafahuaweidfasfaf'

print('huawei' in mystr)

is 判斷兩個(gè)標(biāo)識(shí)符是否引用同一個(gè)對(duì)象

is not 判斷兩個(gè)標(biāo)識(shí)符是否引用不同的對(duì)象

#案例:a1=10,b1=2.經(jīng)過(guò)運(yùn)算,b1+=8,判斷a1和b1是否引用自一個(gè)對(duì)象

a1=10

b1=2

b1+=8

print(a1,b1)結(jié)果為:10 10

print(a1is b1)打印True

運(yùn)算符優(yōu)先級(jí)

運(yùn)算符的優(yōu)先級(jí)在長(zhǎng)表達(dá)式的計(jì)算中有指導(dǎo)運(yùn)算步驟作用

Python中的算術(shù)運(yùn)算符有哪些呢?

1. 比較運(yùn)算符:

如果比較式成立,返回True;不成立,則返回False。

常見(jiàn)的比較運(yùn)算符如下:

除了簡(jiǎn)單的兩值相比之外,比較運(yùn)算符還支持比較復(fù)雜的比較。

(1)多條件比較:

可以先給變量a賦值,然后做多條件比較。

1 a = 3

2 print(1 a 5)

(2)變量的比較:

給變量a和變量b分別賦值,進(jìn)行比較。

1 a = 3

2 b = 3

3 print(a != b)

4

5 s1 = 'duwangdan'

6 s2 = 'DuWangDan'

7 print(s1 == s2)

(3)函數(shù)結(jié)果的比較:

1 print(abs(-1) len('duwagndan'))

2 # abs():返回輸入?yún)?shù)的絕對(duì)值

在比較運(yùn)算中有一些需要留意的小問(wèn)題:

不同類型的對(duì)象不能用“、=、、=”進(jìn)行比較,但可以用“==、!=”做比較。

1 print(21 == len('duwangdan'))

在文章開(kāi)頭說(shuō)過(guò),True對(duì)應(yīng)的是1,F(xiàn)alse對(duì)應(yīng)的是0??聪旅孢@個(gè)例子,F(xiàn)alse+True其實(shí)相當(dāng)于0+1:

1 print(False + True False + False)

2. 成員運(yùn)算符:

成員運(yùn)算符的關(guān)鍵詞是“in”,判斷一個(gè)元素是否在某一個(gè)列表中。運(yùn)行如下程序后,可得到反饋結(jié)果。

1 a = 1

2 b = 'beautiful'

3 album = [1,'beautifully',False,7]

4 # 創(chuàng)建列表,命名該列表為album

5 print(a in album)

6 print(b in album

當(dāng)album=[]時(shí),表示該列表為空。

如果想在album中新增內(nèi)容,可以用append方法來(lái)實(shí)現(xiàn)。新增后,會(huì)在列表末尾顯示新增的內(nèi)容。

1 album = [1,'beautifully',False,7]

2 album.append('Wow')

3 # 用append()方法在album中新增內(nèi)容

4 print(album)

3. 身份運(yùn)算符:

身份運(yùn)算符是用來(lái)比較兩個(gè)對(duì)象是否是同一個(gè)對(duì)象,而之前比較運(yùn)算符中的“==” 則是用來(lái)比較兩個(gè)對(duì)象的值是否相等。

身份運(yùn)算符主要用“is、is not”來(lái)判斷。

1 a = 'duwangdan'

2 b = 'duwangdan'

3 print(a is b)

4 print(a is not b)

4. 布爾運(yùn)算符:

在Python中有3種布爾運(yùn)算符:and、or、not。

如下例子,返回結(jié)果分別為:False、True、True。

1 print(1 2 and 1 0)

2 print(1 2 or 1 0)

3 print(not False)

python運(yùn)算符有哪些

介紹邏輯運(yùn)算符的種類以及使用方法,例子使用pycharm解釋器。

電腦:華為MateBook

系統(tǒng):Windows10

軟件:pycharm解釋器1.0

1、第一個(gè),邏輯與and,就是并且的意思;寫(xiě)法是:a and b (a,b為python對(duì)象),使用方法:如果a為False,a and b返回False,否則它返回b的計(jì)算值。舉例如圖,and左右沒(méi)用其他邏輯計(jì)算僅數(shù)字的情況,(我們知道python中,數(shù)字0即為Fasle,其他數(shù)字為T(mén)rue)。

2、非數(shù)字類型的對(duì)象,使用and時(shí)也是同樣的結(jié)果;例如下圖:(空的列表即為False)。

3、當(dāng)and左右是其他邏輯運(yùn)算的情況;同樣和上面兩種情況一樣。例圖,and兩邊是比較運(yùn)算的結(jié)果。

4、第二個(gè),邏輯或or;也就是或者的意思。寫(xiě)法是:a or b (a,b為python對(duì)象),用法:如果a為T(mén)rue,它返回a的值,否則它返回b的計(jì)算值。第一例子仍以數(shù)字來(lái)說(shuō)明。

5、如果or兩邊是其他的布爾表達(dá)式,用法也是與上面相同的;如圖中例子中or兩邊都是比較運(yùn)算符。

6、第三個(gè):邏輯非not,就是不是的意思;寫(xiě)法not a;(a為python對(duì)象)。用法:如果a為T(mén)rue,則返回False;如果a為False,則返回True。


文章題目:Python運(yùn)算符和函數(shù),python的或運(yùn)算符
文章鏈接:http://weahome.cn/article/hdjhhc.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部