1 / 22

Tips For python 2020

In this presentation you can know the important tips in python.You can seen 20 Python tips and tricks that make it interesting and elegant. These python Tips makes you master in Programming<br><br>Reference : https://nareshit.com/python-online-training/

Download Presentation

Tips For python 2020

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Tips For python 2020

  2. 1. The Zen of Python • The Zen of Python also known as PEP 20 is a small text by Tim Peters that represents the guiding principles to design and use Python. It can be found on Python Web site, but you can also get it in your terminal (console) or Jupyter notebook with a single statement: • >>> import this • The Zen of Python, by Tim Peters • Beautiful is better than ugly. • Explicit is better than implicit. • Simple is better than complex. • Complex is better than complicated. • Flat is better than nested. • Sparse is better than dense. • Readability counts. • Special cases aren't special enough to break the rules. • Although practicality beats purity. • Errors should never pass silently. • Unless explicitly silenced. • In the face of ambiguity, refuse the temptation to guess. • There should be one-- and preferably only one --obvious way to do it. • Although that way may not be obvious at first unless you're Dutch. • Now is better than never. • Although never is often better than *right* now. • If the implementation is hard to explain, it's a bad idea. • If the implementation is easy to explain, it may be a good idea. • Namespaces are one honking great idea -- let's do more of those!

  3. 2. Chained Assignment • If you need multiple variables to reference the same object, you can use the chained assignment: • >>> x = y = z = 2 • >>> x, y, z • (2, 2, 2) • Logical and elegant, right?

  4. 3. Chained Comparison • You can merge multiple comparisons to a single Python expression by chaining the comparison operators. This expression returns True if all comparisons are correct or False otherwise: • >>> x = 5 • >>> 2 < x = 8 • True • >>> 6 < x = 8 • False • This is similar to (2 < x) and (x = 8) and (6 < x) and (x = 8), but more compact and requires x to be evaluated only once. • This is also legal: • >>> 2 < x > 4 • True • You can chain more than two comparisons: • >>> x = 2 • >>> y = 8 • >>> 0 < x < 4 < y < 16 • True

  5. 4. Multiple Assignment • You can assign multiple variables in a single statement using tuple unpacking: • >>> x, y, z = 2, 4, 8 • >>> x • 2 • >>> y • 4 • >>> z • 8 • Please, note that 2, 4, 8 in the first statement is a tuple equivalent to (2, 4, 8).

  6. 5. More Advanced Multiple Assignment • Ordinary multiple assignments are not all Python can do. You don’t need the same number of elements on the left and right sides: • >>> x, *y, z = 2, 4, 8, 16 • >>> x • 2 • >>> y • [4, 8] • >>> z • 16 • In this case, x takes the first value (2) because it comes first. z is the last and takes the last value (8). y takes all other values packed in a list because it has the asterisk (*y).

  7. 6. Swap Variables • You can apply multiple assignments to swap any two variables in a concise and elegant manner, without introducing the third one: • >>> x, y = 2, 8 • >>> x • 2 • >>> y • 8 • >>> x, y = y, x • >>> x • 8 • >>> y 2

  8. 7. Merge Dictionaries • One way to merge two or more dictionaries is by unpacking them in a new dict: • >>> x = {'u': 1} • >>> y = {'v': 2} • >>> z = {**x, **y, 'w': 4} • >>> z • {'u': 1, 'v': 2, 'w': 4}

  9. 8. Join Strings • If you need to join multiple strings, eventually having the same character or group of characters between them, you can use str.join() method: • >>> x = ['u', 'v', 'w'] • >>> y = '-*-'.join(x) • >>> y • 'u-*-v-*-w'

  10. 9. Advance Iteration • If you want to iterate through a sequence and you need both sequence elements and the corresponding indices, you should use enumerate: • >>> for i, item in enumerate(['u', 'v', 'w']): • ... print('index:', i, 'element:', item) • ... • index: 0 element: u • index: 1 element: v • index: 2 element: w • In each iteration, you’ll get a tuple with the index and corresponding element of the sequence.

  11. 10. Reversed Iteration • If you want to iterate through a sequence in the reversed order, you should use reversed: • >>> for item in reversed(['u', 'v', 'w']): • ... print(item) • ... • w • v • u

  12. 11. Aggregate Elements • If you’re going to aggregate the elements from several sequences, you should use zip: • >>> x = [1, 2, 4] • >>> y = ('u', 'v', 'w') • >>> z = zip(x, y) • >>> z • >>> list(z) • [(1, 'u'), (2, 'v'), (4, 'w')] • You can iterate through the obtained zip object or transform it into a list or tuple.

  13. 12. Transpose Matrices • Although people usually apply NumPy (or similar libraries) when working with matrices, you can obtain the transpose of a matrix with zip: • >>> x = [(1, 2, 4), ('u', 'v', 'w')] • >>> y = zip(*x) • >>> z = list(y) • >>> z • [(1, 'u'), (2, 'v'), (4, 'w')]

  14. 13. Unique Values • You can remove duplicates from a list, that is obtained unique values by converting it to a set if the order of elements is not important: • >>> x = [1, 2, 1, 4, 8] • >>> y = set(x) • >>> y • {8, 1, 2, 4} • >>> z = list(y) • >>> z • [8, 1, 2, 4]

  15. 14. Sort Sequences • Sequences are sorted by their first elements by default: • >>> x = (1, 'v') • >>> y = (4, 'u') • >>> z = (2, 'w') • >>> sorted([x, y, z]) • [(1, 'v'), (2, 'w'), (4, 'u')] • However, if you want to sort them according to their second (or other) elements, you can use the parameter key and an appropriate lambda function as the corresponding argument: • >>> sorted([x, y, z], key=lambda item: item[1]) • [(4, 'u'), (1, 'v'), (2, 'w')] • It’s similar if you want to obtain the reversed order: • >>> sorted([x, y, z], key=lambda item: item[1], reverse=True) • [(2, 'w'), (1, 'v'), (4, 'u')]

  16. 15. Sort Dictionaries • You can use a similar approach to sort key-value tuples of dictionaries obtained with .items() method: • >>> x = {'u': 4, 'w': 2, 'v': 1} • >>> sorted(x.items()) • [('u', 4), ('v', 1), ('w', 2)] • They are sorted according to the keys. If you want to them to be sorted according to their values, you should specify the arguments that correspond to key and eventually reverse: • >>> sorted(x.items(), key=lambda item: item[1]) • [('v', 1), ('w', 2), ('u', 4)] • >>> sorted(x.items(), key=lambda item: item[1], reverse=True) • [('u', 4), ('w', 2), ('v', 1)]

  17. 16. Raw Formatted Strings • PEP 498 and Python 3.6 introduced so-called formatted strings or f-strings. You can embed expressions inside such strings. It’s possible and straightforward to treat a string as both raw and formatted. You need to include both prefixes: fr. • >>> fr'u \ n v w={2 + 8}' • 'u \\ n v w=10'

  18. 17. Obtain Current Date and Time • Python has a built-in module datetime that is versatile in working with dates and times. One of its methods, .now(), returns the current date and time: • >>> import datetime • >>> datetime.datetime.now() • datetime.datetime(2019, 5, 20, 1, 12, 31, 230217)

  19. 18. Obtain the Index of the Maximal (or Minimal) Element • Python doesn’t provide a routine to directly get the index of the maximal or minimal element in a list or tuple. Fortunately, there are (at least) two elegant ways to do so: • >>> x = [2, 1, 4, 16, 8] • >>> max((item, i) for i, item in enumerate(x))[1] • 3 • If there are two or more elements with the maximal value, this approach returns the index of the last one: • >>> y = [2, 1, 4, 8, 8] • >>> max((item, i) for i, item in enumerate(y))[1] • 4 • To get the index of the first occurrence, you need to change the previous statement slightly: • >>> -max((item, -i) for i, item in enumerate(y))[1] • 3 • The alternative way is probably more elegant: • >>> x = [2, 1, 4, 16, 8] • >>> max(range(len(x)), key=lambda i: x[i]) • 3 • >>> y = [2, 1, 4, 8, 8] • >>> max(range(len(y)), key=lambda i: x[i]) • 3 • To find the index of the minimal element, use the function min instead of max.

  20. 19. Obtain the Cartesian Product • The built-in module itertools provides many potentially useful classes. One of them is a product used to obtain the Cartesian product: • >>> import itertools • >>> x, y, z = (2, 8), ['u', 'v', 'w'], {True, False} • >>> list(itertools.product(x, y, z)) • [(2, 'u', False), (2, 'u', True), (2, 'v', False), (2, 'v', True), • (2, 'w', False), (2, 'w', True), (8, 'u', False), (8, 'u', True), • (8, 'v', False), (8, 'v', True), (8, 'w', False), (8, 'w', True)]

  21. 20. The Operator for Matrix Multiplication • PEP 465 and Python 3.5 introduced the dedicated infix operator for matrix multiplication @. You can implement it for your class with the methods matmul, rmatmul, and imatmul. This is how elegant the code for multiplying vectors or matrices looks like: • >>> import numpy as np • >>> x, y = np.array([1, 3, 5]), np.array([2, 4, 6]) • >>> z = x @ y • >>> z • 44

  22. Conclusion • You’ve seen 20 Python tips and tricks that make it interesting and elegant. These python Tips makes you master in Programming • Reference : https://nareshit.com/python-online-training/

More Related