あなたのコーディングプロセスをスピードアップする18パイソン1ライナー.


Please don't use these one liners in any interview, or in any production based code. The article is just for fun seeing the replacement of some programs/code block in one line. Some like list comprehension is a must know as well.


こんにちは、私はYash Makanと今日のブログで、我々はPythonの1つのライナーについて話すつもりです.私がはっきりと覚えているのは、Pythonを学ぶことを選んだ時のことでした.しかし、あなたは、コードのより少ない行で、より簡単にPythonコードを作ることができるものを知っています.ああ!thats私の友人右.これらの1つのライナーコードを使用すると、多くの時間、メモリを節約することができますし、お友達を感動させることができます.


ワンライナーコードとは何か
つのライナーコードを1つの線の中に収まるように、圧縮されたコードのブロックと考えることができます.これは簡潔な、便利なプログラムだけで1つの行に満載です.

なぜ私はそれらを必要とするのですか?
それで、あなたが1つのライナーを書く大きなファンでないならば、あるいは、あなたがちょうどなぜ私が以下でこれらを知っていなければならないかについて興味があるならば、以下のかなり説得力のある話題です.
  • あなたが言語のより良い理解を得るように1つのライナーを理解すると、Pythonの専門家になります.
  • これは、コードを速く書くのに役立ちます.あなたは、競争力のあるプログラミングであなたを助ける他のものよりはるかに速くコードの部分を書くことができます.
  • 彼らはあなたの基礎を強化するようにライナーはプログラミングの基礎とルーツを改善します.
  • あなたはPythonの方法でコードをもっと書きます.一般に、異なった言語から来る人々は、しばしばPythonの非Pythonの方法でコードを書きます.例えば、リスト理解、複数の割り当て、およびスライスなどを使用しません.
  • あなたは、1つのライナーの良い把握を持っている場合は、あなたのインタビューで良い印象を与えることができますあなたの友人、同僚を感動させることができます.
  • しかし、また、それは少し難しいことができます.チェスとしてプログラミングを想像してください.基本は、変数、ループ、条件、データ構造、クラスであるが、マスター映画を学んで、あなた自身の戦略をつくることが1つのライナーのようであることを知っているようなものであるということを知っています.初めに、それはハードと非常に圧倒的なことができますが、一度それらを知るようになる.あなたは偉大さを達成することができますし、他の選手の多くよりも速い試合に勝つ.すべては私の友人を支払うために価格があります.

    基礎

    1 .そうであれば
    以前
    if 3 < 2:
        var=21
    else:
        var=42
    
    アフター
    var = 21 if 3<2 else 42
    

    ELIF
    以前
    >>> x = 42
    >>> if x > 42:
    >>>     print("no")
    >>> elif x == 42:
    >>>     print("yes")
    >>> else:
    >>>     print("maybe")
    yes
    
    アフター
    >>> print("no") if x > 42 else print("yes") if x == 42 else print("maybe")
    yes
    

    3 .そうでなければ
    以前
    condition = True
    
    if condition:
        print('hi')
    
    アフター
    if condition: print('hello')
    print('hello') if condition else None
    

    機能
    以前
    def f(x):
        return "hello "+ x
    
    アフター
    f = lambda x: "hello "+ x
    f = exec("def f(x):\n    return 'hello '+ x")
    

    5 .ループ(リスト理解)
    以前
    squares = []
    for i in range(10):
        squares.append(i**2)
    
    アフター
    squares=[i**2 for i in range(10)]
    

    ifループ
    以前
    squares = []
    for i in range(10):
        if i%2==0:
            squares.append(i**2)
    
    アフター
    squares = [i**2 for i in range(10) if i%2==0]
    

    if ifループ
    以前
    squares = []
    for i in range(10):
        if i%2==0:
            squares.append(i**2)
        else:
            squares.append(False)
    
    アフター
    squares = [i**2 if i%2==0 else False for i in range(10)]
    

    8 .そうであればループ
    以前
    c=0
    while c < 10:
        if c!=5:
            print(c)
        else:
            print("FIVE")
        c+=1
    
    アフター
    while c < 10: c+=1; print(c) if c!=5 else print("FIVE")
    

    スワップ変数
    以前
    >>> def swap(x,y):
        x = x ^ y
        y = x ^ y
        x = x ^ y
        return x, y
    >>> swap(10,20)
    (20,10)
    
    アフター
    >>> x, y = 10, 20
    >>> x, y = y, x
    (20, 10)
    

    10 .複数の代入
    以前
    a="ONE"
    b=2
    c=3.001
    
    アフター
    a, b, c = "One", 2, 3.001
    

    11 .ファイルに文字列を書き込む
    以前
    text = "Helllloooooo"
    fileName = "hello.txt"
    f=open(fileName, "a")
    f.write(text)
    f.close()
    
    アフター
    text = "Helllloooooo"
    fileName = "hello.txt"
    print(text, file=open(fileName, 'a'))
    

    クイックソート
    以前
    # Source - https://stackabuse.com/quicksort-in-python/
    
    def partition(array, start, end):
        pivot = array[start]
        low = start + 1
        high = end
    
        while True:
            while low <= high and array[high] >= pivot:
                high = high - 1
    
            while low <= high and array[low] <= pivot:
                low = low + 1
    
            if low <= high:
                array[low], array[high] = array[high], array[low]
            else:
                break
    
        array[start], array[high] = array[high], array[start]
    
        return high
    
    def quick_sort(array, start, end):
        if start >= end:
            return
    
        p = partition(array, start, end)
        quick_sort(array, start, p-1)
        quick_sort(array, p+1, end)
    
    array = [29,99,27,41,66,28,44,78,87,19,31,76,58,88,83,97,12,21,44]
    
    quick_sort(array, 0, len(array) - 1)
    print(array)
    
    アフター
    array = [29,99,27,41,66,28,44,78,87,19,31,76,58,88,83,97,12,21,44]
    q = lambda l: q([x for x in l[1:] if x <= l[0]]) + [l[0]] + q([x for x in l if x > l[0]]) if l else []
    print(q(array))
    

    フィボナッチ
    以前
    def fib(x):
        if x <= 2:
            return 1
        return fib(x - 1) + fib(x - 2)
    
    アフター
    fib=lambda x: x if x<=1 else fib(x-1) + fib(x-2)
    

    14 . HTTPサーバ
    以前
    import http.server
    import socketserver
    PORT = 8000
    Handler = http.server.SimpleHTTPRequestHandler
    with socketserver.TCPServer(("", PORT), Handler) as httpd:
        print("serving at port", PORT)
        httpd.serve_forever()
    
    アフター
    python -m http.server 8000
    

    15 .入れ子になったループ
    以前
    iter1 = [1, 2, 3, 4]
    iter2 = ['a', 'b', 'c']
    for x in iter1:
        for y in iter2:
            print(x, y)
    
    アフター
    [print(x, y) for x in iter1 for y in iter2]
    

    16行目のない印刷
    以前
    for i in range(1,5):
        print(i, end=" ")
    
    アフター
    print(*range(1,5))
    

    17章クラス
    以前
    class School(): 
        fun = {}
    
    アフター
    School = type('School', (object,), {'fun':{}})
    

    18 . Walrus := ( Python 3.8 )
    以前
    command = input("> ")
    while command != "quit":
        print("You entered:", command)
    
    アフター
    while (command := input("> ")) != "quit": print("You entered:", command)
    

    結論
    それで、あなたはPythonの1つのライナーのいくらかの理解を持っています、そして、これはコード化プロセスを速めるのを助けます.私は、私が私が以前に知らなかった若干のいかしたトリックと1人のライナーを知っているように、あなたがこの記事から何か新しいことを学んだことを望みます.これがあなたと同様にケースであるならば、私の動機づけ(1のような1つの良いカルマ)が増加するとき、心臓ボタンをクリックしてください.また、あなたの友人と共有するポストので、あまりにも新しい何かを学ぶことができます.希望はあなたの心の中に再び、それまでB -バイ!


    その他




  • 社会
  • My Website

  • Banner