Functional Programming With Python
Published 12/2023
MP4 | Video: h264, 1920x1080 | Audio: AAC, 44.1 KHz
Language: English | Size: 3.51 GB | Duration: 14h 28m
Published 12/2023
MP4 | Video: h264, 1920x1080 | Audio: AAC, 44.1 KHz
Language: English | Size: 3.51 GB | Duration: 14h 28m
A beginner-friendly introduction to functional constructs in python
What you'll learn
Practical fluency with map, filter, reduce, zip, any, all, list, set, dictionary, and generator comprehensions, and generator expressions
Complete coverage of intermediate functional constructs in Python: generators, iterators, decorators, closures, recursion, and much more!
A practical exploration of advanced topics: closures, recursion, partial function application, currying, memoization, infinite iterators, and overloading
A conceptual understanding of the key tenets of functional programming: immutability, purity, higher-order functions, recursion, and referential transparency
Requirements
No prior Python programming experience is required - this course is beginner friendly
A basic understanding of programming concepts is helpful, but not required
Description
Welcome to the best and most comprehensive introduction to functional programming in Python!In this beginner-friendly course, you will get to learn and practice Python's functional capabilities step-by-step, from the ground up. The course will begin with a conceptual understanding of the key tenets of functional programming: immutability: the idea that data should not be modified in placepurity: the practice of writing functions that do not cause side effectshigher-order functions: treating functions as pari passu with other data typesrecursion: the pattern of writing functions that call themselvesreferential transparency: the principle that a function call can be replaced with its return value without changing the program's behaviorThen, we will explore practical utilities that Python offers to help us write functional code, including:map, filter, reduce, zip, any, all: utilities for working with iterableslist, set, dictionary, and generator comprehensions: concise ways of creating lists, sets, dictionaries, and generatorsgenerator functions and iterators: functions that can be paused and resumedvariable arity: functions that can take a variable number of arguments, unknown at the time of writing the function In the final, and longest part of the course, we will take a look at more advanced topics, including:closures: higher-order functions that can access non-local variablesrecursion: functions that call themselvespartial function application: functions that return other functions, with some arguments pre-filledcurrying: a special case of partial function applicationmemoization: caching the results of function calls to speed up executioninfinite iterators: iterators that never endfunctional overloading: functions that behave differently depending on their inputsThroughtout the course, you will get to practice your newly acquired skills through a set of more than 20 skill challenges, each of which will be followed with a detailed video explanation of the solution that we will walk through together.This course is very beginner-friendly and no python experience is assumed. If you've never worked with Python before, there's a full length introduction to Python programming included as an appendix, covering the fundamentals of the language from the basic data types to containers, control flow, loops, classes, and more. See you inside!
Overview
Section 1: PLEASE DO NOT SKIP
Lecture 1 Very Short Intro
Lecture 2 All Course Notebooks
Section 2: The Five Tenets Of Functional Programming
Lecture 3 The Functional Paradigm
Lecture 4 Section Notebook
Section 3: Functions As First-Class Objects
Lecture 5 Passing Functions As Arguments
Lecture 6 Functions Returning Functions
Lecture 7 Skill Challenge
Lecture 8 Solution
Lecture 9 Section Notebook
Section 4: Functions In Data Structures
Lecture 10 Lists Of Functions
Lecture 11 Skill Challenge
Lecture 12 Solution
Lecture 13 Section Notebook
Section 5: HOFs At A Glance
Lecture 14 Order And Higher-Order Functions
Lecture 15 Skill Challenge
Lecture 16 Solution
Lecture 17 Section Notebook
Section 6: Purity And Side Effects
Lecture 18 Impure Functions
Lecture 19 Purity Is Eliminating (Realistically, Isolating) The Side Effects
Lecture 20 Section Notebook
Section 7: Laziness
Lecture 21 Lazy vs Eager Evaluation
Lecture 22 Chaining Lazy Operations
Lecture 23 Section Notebook
Section 8: Immutability
Lecture 24 Mutable Lists
Lecture 25 Skill Challenge
Lecture 26 Solution
Lecture 27 Extra: Undo/Redo Operations With Immutable Data
Lecture 28 Section Notebook
Section 9: Aliasing
Lecture 29 Aliasing And Unintended Side Effects
Lecture 30 Section Notebook
Section 10: Lambdas
Lecture 31 Anonymous Functions
Lecture 32 A Single Expression
Lecture 33 Good And Bad Uses
Lecture 34 Nesting And In-Place Lambdas
Lecture 35 Skill Challenge
Lecture 36 Solution
Lecture 37 Section Notebook
Section 11: Map
Lecture 38 Transformations
Lecture 39 Mapping Over Multiple Iterables
Lecture 40 Built-Ins
Lecture 41 Skill Challenge
Lecture 42 Solution
Lecture 43 Section Notebook
Section 12: Zip
Lecture 44 The Basic Zip
Lecture 45 Strict Mode
Lecture 46 Unzipping With Splat
Lecture 47 Building Dicts
Lecture 48 Extra: Functional Pipelining
Lecture 49 Skill Challenge
Lecture 50 Solution
Lecture 51 Section Notebook
Section 13: Filter
Lecture 52 Declarative Select
Lecture 53 Multiple Conditions
Lecture 54 Extra: Nested Lambdas
Lecture 55 Chained Filtering
Lecture 56 Skill Challenge
Lecture 57 Solution
Lecture 58 Extra: Alternative Solution With namedtuple
Lecture 59 Section Notebook
Section 14: Any And All
Lecture 60 Any
Lecture 61 All
Lecture 62 Any And All With Filter And Map
Lecture 63 Negation
Lecture 64 Short Circuiting Logic
Lecture 65 Skill Challenge
Lecture 66 Solution
Lecture 67 Section Notebook
Section 15: Reduce
Lecture 68 Accumulate
Lecture 69 The Initial Accumulator
Lecture 70 Skill Challenge
Lecture 71 Solution
Lecture 72 More Applications
Lecture 73 Skill Challenge - Run Length Encoding
Lecture 74 Solution
Lecture 75 Section Notebook
Section 16: Comprehensions
Lecture 76 Introduction To Comprehensions
Lecture 77 Nested List Comprehensions
Lecture 78 Comprehensions Over Multiple Iterables
Lecture 79 Skill Challenge
Lecture 80 Solution
Lecture 81 Section Notebook
Section 17: Set Comprehensions
Lecture 82 From Lists To Sets
Lecture 83 More Advanced Operations
Lecture 84 Skill Challenge
Lecture 85 Solution
Lecture 86 Extra Skill Challenge: Efficient Primes
Lecture 87 Solution
Lecture 88 Section Notebook
Section 18: Dictionary Comprehensions
Lecture 89 Building New Dictionaries
Lecture 90 More Use Cases
Lecture 91 Skill Challenge
Lecture 92 Solution
Lecture 93 Alternative Solution
Lecture 94 Section Notebook
Section 19: Iterators
Lecture 95 Concepts And Foundations
Lecture 96 Implementing The Iterator Protocol
Lecture 97 Section Notebook
Section 20: Generators
Lecture 98 Introduction To Generator Functions
Lecture 99 Generator Expressions
Lecture 100 Two-Way Communication With Generators
Lecture 101 Skill Challenge: Infinite Fibonacci Generator
Lecture 102 Solution
Lecture 103 Alternative Solution
Lecture 104 Extra: Sliding Window Fibonacci With Deque
Lecture 105 Data Pipelining Using Generators
Lecture 106 Section Notebook
Section 21: Variadics
Lecture 107 *args and **kwargs
Lecture 108 Skill Challenge
Lecture 109 Solution
Lecture 110 Section Notebook
Section 22: Nested HOFs
Lecture 111 Higher Order Functions Revisited
Lecture 112 Skill Challenge
Lecture 113 Solution
Lecture 114 Section Notebook
Section 23: Closures
Lecture 115 What Is A Closure?
Lecture 116 Skill Challenge
Lecture 117 Solution
Lecture 118 Section Notebook
Section 24: Decorators
Lecture 119 Introduction To Decorators
Lecture 120 Decorating Parameterized Functions
Lecture 121 Skill Challenge
Lecture 122 Solution
Lecture 123 Section Notebook
Section 25: Advanced Decorators
Lecture 124 Advanced Decorators
Lecture 125 Chaining Multiple Decorators
Lecture 126 Preserving Identity With @wraps
Lecture 127 Skill Challenge
Lecture 128 Solution
Lecture 129 Section Notebook
Section 26: Recursion
Lecture 130 Introduction To Recursion
Lecture 131 Recursion Trees And Recurrence Relations
Lecture 132 Skill Challenge
Lecture 133 Solution
Lecture 134 Tail Recursion And Recursion Limits In Python
Lecture 135 Mutual Recursion
Lecture 136 Parsing Structured Data With Recursive Functions
Lecture 137 A Slight Improvement
Lecture 138 Skill Challenge - Recursive Binary Search
Lecture 139 Solution
Lecture 140 Skill Challenge - Refactored Signature
Lecture 141 Solution
Lecture 142 Section Notebook
Section 27: Memoization
Lecture 143 A Conceptual Understanding
Lecture 144 Defining A Memoization Function
Lecture 145 Predefined Caching Utilities
Lecture 146 Extra: Inline Memoization
Lecture 147 Section Notebook
Section 28: Currying And Partials
Lecture 148 Partial Function Application
Lecture 149 Skill Challenge
Lecture 150 Solution
Lecture 151 Section Notebook
Section 29: Overloading And Polymorphism With singledispatch
Lecture 152 Polymorphic Functions
Lecture 153 A Quick Gotcha
Lecture 154 Skill Challenge
Lecture 155 Solution
Lecture 156 Section Notebook
Section 30: Infinite Iterators
Lecture 157 Count
Lecture 158 Infinite Cycles
Lecture 159 Finite Cycles With Repeat
Lecture 160 Skill Challenge
Lecture 161 Solution
Lecture 162 Section Notebook
Section 31: Appendix: Complete Python Fundamentals In Less Than 3 Hours
Lecture 163 Please Note
Lecture 164 Section Intro
Lecture 165 Data Types
Lecture 166 Variables
Lecture 167 Arithmetic And Augmented Assignment Operators
Lecture 168 Ints And Floats
Lecture 169 Booleans And Comparison Operators
Lecture 170 Strings
Lecture 171 Methods
Lecture 172 Containers I: Lists
Lecture 173 Lists vs. Strings
Lecture 174 List Methods And Functions
Lecture 175 Containers II: Tuples
Lecture 176 Containers III: Sets
Lecture 177 Containers IV: Dictionaries
Lecture 178 Dictionary Keys And Values
Lecture 179 Membership Operators
Lecture 180 Controlling Flow: if, else, And elif
Lecture 181 Truth Value Of Non-booleans
Lecture 182 For Loops
Lecture 183 The range() Immutable Sequence
Lecture 184 While Loops
Lecture 185 Break And Continue
Lecture 186 Zipping Iterables
Lecture 187 List Comprehensions
Lecture 188 Defining Functions
Lecture 189 Function Arguments: Positional vs Keyword
Lecture 190 Lambdas
Lecture 191 Importing Modules
This course is for anyone who wants to learn functional programming in Python from the very basics,Beginners to programming interested in writing concise, readable, and maintainable Python,Beginner Python developers with an interest in functional programming,Intermediate programmers with no exposure to functional constructs in Python