1. 非常實用的 Python 技巧

        共 3562字,需瀏覽 8分鐘

         ·

        2020-08-17 06:16

        函數(shù)連續(xù)調(diào)用

        def add(x):
        class AddNum(int):
        def __call__(self, x):
        return AddNum(self.numerator + x)
        return AddNum(x)

        print add(2)(3)(5)
        # 10
        print add(2)(3)(4)(5)(6)(7)
        # 27

        # javascript 版
        var add = function(x){
        var addNum = function(x){
        return add(addNum + x);
        };

        addNum.toString = function(){
        return x;
        }
        return addNum;
        }

        add(2)(3)(5)//10
        add(2)(3)(4)(5)(6)(7)//27

        默認值陷阱

        >>> def evil(v=[]):
        ... v.append(1)
        ... print v
        ...
        >>> evil()
        [1]

        >>> evil()
        [1, 1]

        讀寫csv文件

        import csv

        with open('data.csv', 'rb') as f:
        reader = csv.reader(f)
        for row in reader:
        print row

        # 向csv文件寫入
        import csv

        with open( 'data.csv', 'wb') as f:
        writer = csv.writer(f)
        writer.writerow(['name', 'address', 'age']) # 單行寫入
        data = [
        ( 'xiaoming ','china','10'),
        ( 'Lily', 'USA', '12')]

        writer.writerows(data) # 多行寫入

        數(shù)制轉(zhuǎn)換

        >>> int('1000', 2)
        8

        >>> int('A', 16)
        10

        格式化 json

        echo'{"k": "v"}' | python-m json.tool

        list 扁平化

        list_ = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
        [k for i in list_ for k in i] #[1, 2, 3, 4, 5, 6, 7, 8, 9]
        import numpy as np
        print np.r_[[1, 2, 3], [4, 5, 6], [7, 8, 9]]

        import itertools
        print list(itertools.chain(*[[1, 2, 3], [4, 5, 6], [7, 8, 9]]))
        sum(list_, [])
        flatten = lambda x: [y for l in x for y in flatten(l)] if type(x) is list else [x]
        flatten(list_)

        list 合并

        >>> a = [1, 3, 5, 7, 9]
        >>> b = [2, 3, 4, 5, 6]
        >>> c = [5, 6, 7, 8, 9]
        >>> list(set().union(a, b, c))
        [1, 2, 3, 4, 5, 6, 7, 8, 9]

        出現(xiàn)次數(shù)最多的 2 個字母

        from collections import Counter
        c = Counter('hello world')
        print(c.most_common(2)) #[('l', 3), ('o', 2)]

        謹慎使用

        eval("__import__('os').system('rm -rf /')", {})

        置換矩陣

        matrix = [[1, 2, 3],[4, 5, 6]]
        res = zip( *matrix ) # res = [(1, 4), (2, 5), (3, 6)]

        列表推導(dǎo)

        [item**2 for item in lst if item % 2]
        map(lambda item: item ** 2, filter(lambda item: item % 2, lst))
        >>> list(map(str, [1, 2, 3, 4, 5, 6, 7, 8, 9]))
        ['1', '2', '3', '4', '5', '6', '7', '8', '9']

        排列組合

        >>> for p in itertools.permutations([1, 2, 3, 4]):
        ... print ''.join(str(x) for x in p)
        ...
        1234
        1243
        1324
        1342
        1423
        1432
        2134
        2143
        2314
        2341
        2413
        2431
        3124
        3142
        3214
        3241
        3412
        3421
        4123
        4132
        4213
        4231
        4312
        4321

        >>> for c in itertools.combinations([1, 2, 3, 4, 5], 3):
        ... print ''.join(str(x) for x in c)
        ...
        123
        124
        125
        134
        135
        145
        234
        235
        245
        345
        >>> for c in itertools.combinations_with_replacement([1, 2, 3], 2):
        ... print ''.join(str(x) for x in c)
        ...
        11
        12
        13
        22
        23
        33
        >>> for p in itertools.product([1, 2, 3], [4, 5]):
        (1, 4)
        (1, 5)
        (2, 4)
        (2, 5)
        (3, 4)
        (3, 5)

        默認字典

        >>> m = dict()
        >>> m['a']
        Traceback (most recent call last):
        File "", line 1, in
        KeyError: 'a'
        >>>
        >>> m = collections.defaultdict(int)
        >>> m['a']
        0
        >>> m['b']
        0
        >>> m = collections.defaultdict(str)
        >>> m['a']
        ''
        >>> m['b'] += 'a'
        >>> m['b']
        'a'
        >>> m = collections.defaultdict(lambda: '[default value]')
        >>> m['a']
        '[default value]'
        >>> m['b']
        '[default value]'

        反轉(zhuǎn)字典

        >>> m = {'a': 1, 'b': 2, 'c': 3, 'd': 4}
        >>> m
        {'d': 4, 'a': 1, 'b': 2, 'c': 3}
        >>> {v: k for k, v in m.items()}
        {1: 'a', 2: 'b', 3: 'c', 4: 'd'}

        更多

        1. https://www.zhihu.com/question/27376156

        2. stackoverflow.com/questions/101268/hidden-features-of-python

        3. https://zhuanlan.zhihu.com/p/22909144

        4. https://www.zhihu.com/question/29995881



        零基礎(chǔ)學 Python,請往看下嘛
        送價值 109 經(jīng)典 配套視頻課

        ?只需7天時間,跨進Python編程大門,已有3800+加入
        【基礎(chǔ)】0基礎(chǔ)入門python,24小時有人快速解答問題;
        【提高】40多個項目實戰(zhàn),老手可以從真實場景中學習python;
        【直播】不定期直播項目案例講解,手把手教你如何分析項目;
        【分享】優(yōu)質(zhì)python學習資料分享,讓你在最短時間獲得有價值的學習資源;圈友優(yōu)質(zhì)資料或?qū)W習分享,會不時給予贊賞支持,希望每個優(yōu)質(zhì)圈友既能賺回加入費用,也能快速成長,并享受分享與幫助他人的樂趣。
        【人脈】收獲一群志同道合的朋友,并且都是python從業(yè)者
        【價格】本著布道思想,只需 69元 加入一個能保證學習效果的良心圈子。
        【贈予】價值109元 0基礎(chǔ)入門在線課程,免費送給圈友們,供鞏固





        瀏覽 34
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

        分享
        舉報
        評論
        圖片
        表情
        推薦
        點贊
        評論
        收藏
        分享

        手機掃一掃分享

        分享
        舉報
          
          

            1. 猛烈顶弄h禁欲律师1v1视频 | 51色色 | 26uuu亚洲精品国产精 | 国产剧情演绎av 国产视频精品视频 | 日本成人一级A片 |