• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            sunrise

            每天不斷學習,才能不斷提升自己。

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              64 隨筆 :: 0 文章 :: 92 評論 :: 0 Trackbacks

                 1.原始字符串
                  Python中的原始字符串以r開頭,使用原始字符串可以避免字符串中轉義字符帶來的問題,例如寫路徑時 path = 'c:\noway',此時用 print path,其結果為:
             c:
            oway
                如果用原始字符串 path = r'c:\noway',則 print path,其結果為:c:\noway
                  2.python中沒有字符的概念,字符即長度為1的字串。
                  3.字符串之間的轉換:
                  1) 字符串和數字之間的轉換:
                   int(x [,radix])
                   long(x [,radix])
                   float(x);
                   round(num [,digit])
                  complex(real [,imaginary]):轉換為復數
                  ord(ch):轉換為ascii碼

                  2)數字和字符串之間的轉換:
                  1 chr(x) unichr(x):將ascii碼或者unicode轉換為字符
                  2將數字轉換為16或者8進制 oct(x) hex(x)
                  3 str(obj) 將任何對象轉換為字符串
             
                  4.字符串中的處理方法

            摘錄其整理的表格,供參考:

            類型

            方法

            注解

            填充

            center(width[, fillchar]),
            ljust(width[, fillchar]),
            rjust(width[, fillchar]),
            zfill(width),
            expandtabs([tabsize])

            • fillchar 參數指定了用以填充的字符,默認為空格
            • zfill的z為zero的縮寫,顧名思義,是以字符0進行填充,用于數值輸出
            • expandtabs()的tabsize 參數默認為8。它的功能是把字符串中的制表符(tab)轉換為適當數量的空格。

            刪減

            strip([chars]),
            lstrip([chars]),
            rstrip([chars])

            chars為指定要去掉的字符,默認為空白字符,它由string.whitespace常量定義

            變形

            lower(),#全部小寫
            upper(),#全部小寫
            capitalize(),#首字母大寫
            swapcase(),#大小寫交換
            title()#每個單詞第一個大寫,其他小寫

            因為title() 函數并不去除字符串兩端的空白符也不會把連續的空白符替換為一個空格,
            所以建議使用string 模塊中的capwords(s)函數,它能夠去除兩端的空白符,再將連續的空白符用一個空格代替。

            >>> ‘ hello world!’.title()

            ‘ Hello World!’

            >>> string.capwords(‘ hello world!’)

            ‘Hello World!’

            切割

            partition(sep),
            rpartition(sep),
            splitlines([keepends]),
            split([sep [,maxsplit]]),
            rsplit([sep[,maxsplit]])

            • partition()函數族是2.5版本新增的方法。它接受一個字符串參數,并返回一個3個元素的 tuple 對象。
              如果sep沒出現在母串中,返回值是 (sep, ‘’, ‘’);
              否則,返回值的第一個元素是 sep 左端的部分,第二個元素是 sep 自身,第三個元素是 sep 右端的部分。
            • 參數 maxsplit 是分切的次數,即最大的分切次數,所以返回值最多有 maxsplit+1 個元素。
            • s.split() 和 s.split(‘ ‘)的返回值不盡相同
            • >>> ‘ hello world!’.split()
            • ['hello', 'world!']
            • >>> ‘ hello world!’.split(‘ ‘)
            • ['', '', 'hello', '', '', 'world!']

            產生差異的原因在于當忽略 sep 參數或sep參數為 None 時與明確給 sep 賦予字符串值時 split() 采用兩種不同的算法。
            對于前者,split() 先去除字符串兩端的空白符,然后以任意長度的空白符串作為界定符分切字符串
            即連續的空白符串被當作單一的空白符看待;
            對于后者則認為兩個連續的 sep 之間存在一個空字符串。因此對于空字符串(或空白符串),它們的返回值也是不同的:

            >>> ”.split()

            []

            >>> ”.split(‘ ‘)

            ['']

            連接

            join(seq)

            join() 函數的高效率(相對于循環相加而言),使它成為最值得關注的字符串方法之一。
            它的功用是將可迭代的字符串序列連接成一條長字符串,如:

            >>> 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′

            判定

            isalnum(),
            isalpha(),
            isdigit(),
            islower(),
            isupper(),
            isspace(),
            istitle(),
            startswith(prefix[, start[, end]]),
            endswith(suffix[,start[, end]])

            這些函數都比較簡單,顧名知義。需要注意的是*with()函數族可以接受可選的 start, end 參數,善加利用,可以優化性能。
            另,自 Py2.5 版本起,*with() 函數族的 prefix 參數可以接受 tuple 類型的實參,當實參中的某人元素能夠匹配,即返回 True。

            查找

            count( sub[, start[, end]]),
            find( sub[, start[, end]]),
            index( sub[, start[, end]]),
            rfind( sub[, start[,end]]),
            rindex( sub[, start[, end]])

            find()函數族找不到時返回-1,index()函數族則拋出ValueError異常。
            另,也可以用 in 和 not in 操作符來判斷字符串中是否存在某個模板。

            替換

            replace(old, new[,count]),
            translate(table[,deletechars])

            replace()函數的 count 參數用以指定最大替換次數
            translate() 的參數 table 可以由 string.maketrans(frm, to) 生成
            translate() 對 unicode 對象的支持并不完備,建議不要使用。

            編碼

            encode([encoding[,errors]]),
            decode([encoding[,errors]])

            這是一對互逆操作的方法,用以編碼和解碼字符串。因為str是平臺相關的,它使用的內碼依賴于操作系統環境,
            而unicode是平臺無關的,是Python內部的字符串存儲方式。
            unicode可以通過編碼(encode)成為特定編碼的str,而str也可以通過解碼(decode)成為unicode。

             

            posted on 2012-03-19 10:34 SunRise_at 閱讀(2579) 評論(0)  編輯 收藏 引用 所屬分類: 可愛的python
            亚洲乱码精品久久久久..| 亚洲色大成网站www久久九| 久久影院综合精品| 亚洲AV无码久久精品色欲| 久久久精品国产免大香伊| 久久99精品国产自在现线小黄鸭| 熟妇人妻久久中文字幕| 成人久久精品一区二区三区| 久久这里只精品国产99热| 性做久久久久久久久| 精品免费久久久久久久| 色99久久久久高潮综合影院| 东京热TOKYO综合久久精品 | 久久露脸国产精品| 99久久er这里只有精品18| 日韩亚洲国产综合久久久| 97久久精品国产精品青草| 亚洲AV成人无码久久精品老人| 久久成人18免费网站| 久久综合狠狠综合久久激情 | 少妇高潮惨叫久久久久久| 精品伊人久久大线蕉色首页| yellow中文字幕久久网| 狠狠色丁香久久婷婷综合五月| 97久久国产综合精品女不卡 | 久久综合中文字幕| 国产精品99久久久久久人| 精品久久久久久久| 久久97久久97精品免视看秋霞 | 亚洲人成电影网站久久| 性高朝久久久久久久久久| 日本强好片久久久久久AAA| 久久精品人人做人人爽电影蜜月 | 久久久久av无码免费网| 久久精品午夜一区二区福利| 青青草国产精品久久| 免费精品久久天干天干| 91精品婷婷国产综合久久| 久久久久久精品免费免费自慰| 国产精品无码久久久久久| 午夜天堂精品久久久久|