New Features You Need To Know In Python 3.12

Поделиться
HTML-код
  • Опубликовано: 31 июл 2024
  • Python 3.12 is just around the corner, and I couldn't be more excited! 🎉🐍 In this video, I'll not only dive into the thrilling new features and improvements coming our way in Python 3.12 but also discuss some elements that will be removed in the upcoming release.
    💡 Get my FREE 7-step guide to help you consistently design great software: arjancodes.com/designguide.
    💻 ArjanCodes Blog: www.arjancodes.com/blog
    ✍🏻 Take a quiz on this topic: www.learntail.com/quiz/jlpmsd
    🎓 Courses:
    The Software Designer Mindset: www.arjancodes.com/mindset
    The Software Architect Mindset: Pre-register now! www.arjancodes.com/architect
    Next Level Python: Become a Python Expert: www.arjancodes.com/next-level...
    The 30-Day Design Challenge: www.arjancodes.com/30ddc
    🛒 GEAR & RECOMMENDED BOOKS: kit.co/arjancodes.
    👍 If you enjoyed this content, give this video a like. If you want to watch more of my upcoming videos, consider subscribing to my channel!
    Social channels:
    💬 Discord: [discord.arjan.codes](discord.arjan.codes/)
    🐦Twitter: / arjancodes
    🌍LinkedIn: / arjancodes
    🕵Facebook: / arjancodes
    📱Instagram: / arjancodes
    ♪ Tiktok: / arjancodes
    👀 Code reviewers:
    - Yoriz
    - Ryan Laursen
    - Dale Hagglund
    🎥 Video edited by Mark Bacskai: / bacskaimark
    🔖 Chapters:
    0:00 Intro
    0:51 Better error messages
    2:06 Performance improvements
    2:28 Comprehension inlining
    3:26 Smaller object sizes
    3:41 Immortal objects
    4:39 Per-interpreter GIL (PEP684)
    5:47 F-strings
    6:36 TypedDict kwargs
    7:32 Override decorator
    8:26 Generic types
    10:24 Other
    11:37 Outro
    #arjancodes #softwaredesign #python
    DISCLAIMER - The links in this description might be affiliate links. If you purchase a product or service through one of those links, I may receive a small commission. There is no additional charge to you. Thanks for supporting my channel so I can continue to provide you with free content each week!

Комментарии • 248

  • @ArjanCodes
    @ArjanCodes  9 месяцев назад +1

    💡 Get my FREE 7-step guide to help you consistently design great software: arjancodes.com/designguide.

  • @JohnWalz97
    @JohnWalz97 10 месяцев назад +108

    We make use of kwargs in our library for passing user arguments to functions from other libraries (i.e in our wrapper functions)

    • @Mr1995Musicman
      @Mr1995Musicman 10 месяцев назад +30

      If I remember correctly, packages with graphing capability like pandas and seabourn use this to enable pass-through args to the underlying matplotlib graph object.
      One thing I'd love to see is improvements to the documentation of kwargs, it can get very frustrating, even though it'd very powerful.

    • @PixelThorn
      @PixelThorn 10 месяцев назад +10

      kwargs are very powerful, especially when used with args, but the price you pay for the flexibility is obfuscation, if we could have all the benefits without the obfuscation, then that would be amazing

    • @FabriceNormandin95
      @FabriceNormandin95 10 месяцев назад

      ​@@PixelThornyou might like typing.ParamSpec, helps a lot for this kind of thing

    • @sebastianrodriguezcolina634
      @sebastianrodriguezcolina634 10 месяцев назад

      Such practice requieres you to know implementation details of the function, I dislike that in general.

    • @therainman7777
      @therainman7777 10 месяцев назад

      @@sebastianrodriguezcolina634Like most things in software engineering, there is a trade off between power/expressiveness and clarity/safety. Python already leans toward power/expressiveness in most aspects (dynamic typing, etc.), so using kwargs is at least pretty consistent with other conventions available in Python.

  • @navidshokouhi
    @navidshokouhi 10 месяцев назад +63

    I have two use cases for kwargs:
    1. when creating a wrapper function for another function.
    2. when passing around parameters for ML and data science projects. Typically I store these as json files, so it’s nice to use dictionaries to pass around those parameters.

    • @kelkka7
      @kelkka7 10 месяцев назад

      Do you have an example I could learn from?

    • @csanadtemesvari9251
      @csanadtemesvari9251 10 месяцев назад

      @@kelkka7no

    • @karolkurek9201
      @karolkurek9201 10 месяцев назад

      @@kelkka7 Check how to write decorators for functions with arguments.

    • @thomasjamesbullock
      @thomasjamesbullock 10 месяцев назад

      This. I do this as well. Nice and clean.

    • @daniel.lupton
      @daniel.lupton 9 месяцев назад +1

      Also when making an abstract or parent class, different child classes might need different arguments in their constructors and other functions. As you can't control how future developers will extend the class, you need to keep some functions generic. This is similar to the wrapper use case, except in this instance you're wrapping functions that might not exist yet.

  • @ihordrahushchak5439
    @ihordrahushchak5439 10 месяцев назад +5

    Hey @ArjanCodes, if you want function annotations, then create a Protocol class and define the __call__ method and then add the type anotations for the parameters in that __call__ method. When you will use the the Protocol to type a function it will describe it with the type of the __call__ method.

  • @landwolf00
    @landwolf00 10 месяцев назад +9

    Kwargs are a really great feature when you are writing larger repositories. When passing arguments to other repeatedly called functions, this makes the code much cleaner. One example if with spark dataframes. I have one function that does all of the filtering with arguments per column. Most other functions call this function at the beginning with kwargs being passed directly to it.

  • @sinkingboat101
    @sinkingboat101 10 месяцев назад +17

    I have not used kwargs too much myself, but I have seen some really good use cases. One of them is collecting a bunch of optional (kw) arguments at top level, and then reducing the kwargs dict as you move down the tree of functions or methods, as each of them have explicit named arguments set by some of the kwargs provided by their "parent" function (the caller) and then collecting the remainder as a smaller kwargs dict passed to their children.

    • @banatibor83
      @banatibor83 10 месяцев назад +5

      Super terrible idea! Do this and after a month you won't have any idea what inputs your method require. When you feel the need for kwargs use a class.

  • @josealejandroconcepcion2025
    @josealejandroconcepcion2025 10 месяцев назад +4

    I usually use *args and **kwargs when creating custom decorators. I like to create decorators for code reusability and custom tools for my projects. Also a custom paters is the composition and some time you can create some custom wrappers utilities that receive an object instance with some arbitrary parameters and you perform some kind of logic.

  • @markchadwick77
    @markchadwick77 10 месяцев назад +3

    Thanks for again for your excellent content. I would love to see a comprehensive tutorial for typing. All of existing ones go through the basics, but someone needs to explain how I can get VSCode and Black to pass on real code with a "strict" setting.

  • @mayureshkedari3799
    @mayureshkedari3799 10 месяцев назад +6

    I would love to see more content in the form of series on
    1. threading vs multiprocessing
    2. distributed computing in python using ray framework or its equivalent

  • @MegaJolaus
    @MegaJolaus 10 месяцев назад +1

    Using kwargs with argparse for passing command line args to the program entry point is one of my favorite Python patterns. Nothing more satisfying than writing main(**vars(args)) instead of passing everything to main manually.

  • @sugo8920
    @sugo8920 10 месяцев назад +4

    Yes i use kwargs when I have a wrapper function over a core function and I still want to provide all the functionality of the core function without having to update the params in two places.

  • @jjcbvg
    @jjcbvg 10 месяцев назад

    Using kwargs in Django view helpers. Have a few pdf reports that require generation and using pdfkit underneath. So kwargs is being used to pass context for pdf report generation and then also for configuring pdfkit

  • @onhazrat
    @onhazrat 10 месяцев назад +2

    🎯 Key Takeaways for quick navigation:
    00:56 🐍 Python 3.12 introduces improved error messages, including suggestions for missing imports and common coding errors, enhancing the coding experience.
    02:24 🚀 Python 3.12 brings performance improvements, particularly in comprehension inlining, resulting in up to 2x speedup in some cases and an overall 11% performance boost.
    03:51 🧊 Python 3.12 introduces "immortal objects," objects with a fixed reference count, reducing memory usage and simplifying code optimization.
    04:49 🌐 Python 3.12 lays the foundation for per-interpreter Global Interpreter Lock (GIL), enhancing multi-core utilization in future versions.
    05:48 📜 F-strings in Python 3.12 become less restrictive, allowing nested double quotes for improved string formatting.
    06:44 🎯 Python 3.12 simplifies type annotations, allowing for easier definition of keyword argument types and introduces the "override" keyword for explicit method overriding.
    08:40 🧬 Python 3.12 introduces a new syntax for type parameters and generic classes/functions, simplifying the handling of generics.
    10:32 📂 Pathlib now includes a "walk" method, making it easier to traverse directory trees, and CPython 3.12 supports instrumentation for monitoring calls, returns, lines, and exceptions, improving debugging and coverage tools.
    11:28 ❌ Python 3.12 removes deprecated modules like asyncore and asynchat, encourages the use of async.io, and deprecates old method names in the unit test package.
    Made with HARPA AI

  • @bersi3306
    @bersi3306 10 месяцев назад +2

    override decorator is a nice addition. Before every method was virtual. Now you have a bit more control over it.

  • @jevandezande
    @jevandezande 10 месяцев назад +8

    Nested quotes in f-strings is a useful feature when refactoring, and I think a good choice to allow (there was significant debate on this one). However, it also looks bad and is harder to quickly parse visually, thus I hope code formatters will reformat it when possible. This would make for a nice compromise, because if I refactor my code to place a string inside of an f-strings, I could get the ease of readability of alternating quote types with a simple call to my formatter.

  • @CountChocula
    @CountChocula 10 месяцев назад +3

    the TypedDict kwargs feature will be useful for cases where we have function params that are being passed around or through as a group

  • @swannie1503
    @swannie1503 10 месяцев назад

    I have a query builder that passes user arguments (optional and required) along to a DB client as a formatted query string. Good for when I have to maintain a lot of different etl and dbt pipelines and want to use the same basic development pattern for them. In general kwarg unpacking is really invaluable or any kind of client wrapper function or class.

  • @drweb1210
    @drweb1210 10 месяцев назад +1

    The place that i use kwargs is when passing arguments to celery tasks in flask applications

  • @MrAlanCristhian
    @MrAlanCristhian 10 месяцев назад +5

    The override decorator is my favorite new feature.

  • @Andrumen01
    @Andrumen01 10 месяцев назад

    5:48 (f-strings), very much needed and appreciated!

  • @MartinVotruba4
    @MartinVotruba4 9 месяцев назад +1

    The enablement of having nested quotes in f-string is great when you need to access some dictionary field inside the f-string.

  • @alexanderscott2456
    @alexanderscott2456 10 месяцев назад

    Double quotes in f-strings is life-changing. How did I ever life without this?

  • @vikassalaria24
    @vikassalaria24 10 месяцев назад

    @Arjan,You are the best python programmer. Waiting for your architecture course!

  • @GOTHICforLIFE1
    @GOTHICforLIFE1 10 месяцев назад

    I only use kwargs for input cases, and even then it's rarely used as there aren't too many cases where you can't write an explicit alternative

  • @sloan00
    @sloan00 10 месяцев назад +3

    10:06 I agree with you, but sadly the PEP for it is rejected. See PEP 677.

  • @Kenshinse312
    @Kenshinse312 10 месяцев назад

    One of the common cases for kwargs is when you need to pass-through args to os.execv. For example for cli tools that wrap something.

  • @Muslim-uc2bh
    @Muslim-uc2bh 10 месяцев назад

    Thanks for the update.

  • @cetilly
    @cetilly 10 месяцев назад

    Your sense of humor is on point today!

  • @user-mc1oc9oq3b
    @user-mc1oc9oq3b 9 месяцев назад

    One thing I was playing around with was using a combination of inspect and vars() to loop through each function, extract the arguments it needs and select the appropriate variable(s) from vars() to pass in. This is nice when variable names match the function argument names so it's not perfect but useful in some cases. I don't have to worry about figuring out exactly what a function needs. I'm sure there are negatives to this as well but it's one way I like.

  • @iHadar
    @iHadar 10 месяцев назад

    We're using kwargs mostly in forward method for pytorch models. It allows for versatile forward implementation like diffusion models that take not only input but also timestamp, as well as other tailor made models that require more than just input. This way we don't have to break our model interface or split it

  • @saralightbourne
    @saralightbourne 9 месяцев назад

    7:23 - yeah, all the time. i come from languages where this is necessary so it's more of a habit. but i enjoy reading and refactoring code that has type annotations, it speeds up my work tremendously

  • @SpoonOfDoom
    @SpoonOfDoom 8 месяцев назад

    I usually try to avoid kwargs as well, but it is useful when making a wrapper around something that either has *a lot* of parameters or itself has a kwargs that you need to supply.

  • @KyleLi
    @KyleLi 10 месяцев назад +5

    It’s be pretty funny to see a Python 3.14 version nicknamed Pi-thon with a bunch of circle based updates

  • @MrAntLans
    @MrAntLans 10 месяцев назад +1

    Thanks for review! Which theme do you use for VS Code?

  • @user-uo1go7ku7h
    @user-uo1go7ku7h 10 месяцев назад

    kwargs are suitable for metaprogramming, especially when making libraries. I use them for making general functions for tests.

  • @EW-mb1ih
    @EW-mb1ih 10 месяцев назад

    Thank you for your video. I've never used Generic function or class. Wouldn't it be interesting if you do a video on it?

  • @insanecbrotha
    @insanecbrotha 10 месяцев назад +1

    I use kwargs mostly in the inner functions of decorators; here I want a very generic function interface to allow any function to be decorated. But other than that I agree, kwargs are kind of fuzzy. I saw a really bad use case for kwargs in a multiple inheritance example once, where kwargs where used to 'bubble up' arguments through an inheritance chain lol.

  • @MrMrdbarros
    @MrMrdbarros 10 месяцев назад

    I tried using kwargs in that pattern that you keep passing it down and each layer gets its parameters, but I think it gets really messy after some time. But I do use it in the signature in some situations where I , for example, load a config and want to initialize an object with it. I'd call it like **config. The object gets what it wants from the config, but I don't pass kwargs further down. I find it especially useful when the code is changing quickly.

  • @serenditymuse
    @serenditymuse 10 месяцев назад +2

    Mainly a yawn except for better comprehension speed and better GIL lock optimization which really isn't surfaced. Type annotation stuff leaves me quite cold because if I wanted a typed language I would use something else in the first place.

  • @extraordinaire78
    @extraordinaire78 10 месяцев назад

    Keyword arguments make sense when you are writing code where you don't know your inputs. For example, I had written a Python PowerShell wrapper function which would take a unknown number of arguments but the logic to execute the code was mainly the same. Very special use case but I agree that I can't see a reason to use it much.

  • @alexanderpotts8425
    @alexanderpotts8425 10 месяцев назад

    Keyword args are fairly important when writing data pipelines in Apache Airflow

  • @rammcconnell
    @rammcconnell 10 месяцев назад +5

    Amazing! Almost all of these changes are things that have personally annoyed me many times. Python has been killing it recently with these updates.

  • @JPy90
    @JPy90 10 месяцев назад

    6:30 I think is important that new feature, I recently build an API for NLP, and the user can input strings, and if the string had " character, the pydantic validator returned 422 status. I think that now could be fixed, right?

  • @abomayeeniatorudabo8203
    @abomayeeniatorudabo8203 10 месяцев назад +13

    The new generic style and the new type alias function is what I'm more excited about.

    • @sohangchopra6478
      @sohangchopra6478 10 месяцев назад +2

      Same, plus Unpack and TypedDict for type annotating kwargs is quite useful

    • @abomayeeniatorudabo8203
      @abomayeeniatorudabo8203 10 месяцев назад

      @@sohangchopra6478 yea I can't wait to get to use them.

  • @ninjascotsman
    @ninjascotsman 10 месяцев назад +1

    for the beginner these new error messages are amazing and so more useful!

  • @havenisse2009
    @havenisse2009 10 месяцев назад +13

    I'd love to see a beginner guide on how to upgrade from 3.1x to 3.12.. Including getting all the globally installed modules carried over and working.

    • @banatibor83
      @banatibor83 10 месяцев назад +1

      That depends on how outdated your dependencies are. We just finished upgrading a big system from 3.6 to 3.11. It was extremely painful! From 3.1x to 3.12 it should be a piece of cake.

    • @alexanderscott2456
      @alexanderscott2456 10 месяцев назад

      There really won't be any price to pay for upgrading from a recent version of Python. It should be seamless except for certain packages which will need to release wheels for that build. You should be fine.

  • @axeman0707
    @axeman0707 9 месяцев назад

    I used keywords arguments for web handlers so that I can convert responses to an object very quickly and don't have to worry about excess properties coming from the frontend.

  • @Ossiekar
    @Ossiekar 9 месяцев назад

    A video about Python 3.12 that has a duration of 12.03. Nice!

  • @jasonjarosz5897
    @jasonjarosz5897 10 месяцев назад +1

    As a data scientist, I use kwargs a lot because a lot of the code I work with needs to be run in many configurations during experimentation.For example, model training loops can be way easier to control with a function that uses kwargs.

    • @Daniel_Zhu_a6f
      @Daniel_Zhu_a6f 10 месяцев назад

      most languages don't rely on variadic arguments outside of string formatting/collection creation, and nobody complains.
      python's variadic arguments are a prefect example of induced demand. most languages would define structs/data classes like LineStyle or ModelConfig, but python does kwargs.

  • @MatthewBreithaupt
    @MatthewBreithaupt 10 месяцев назад

    The only place I can think of where kwargs are appropriate is when writing function decorators (or any other kind of delegates)

  • @Lemmy4555
    @Lemmy4555 10 месяцев назад

    Nice, the typevar hustle was one of the reasons I switched to Julia

  • @derzemel
    @derzemel 10 месяцев назад

    I have used kwargs only for decorator functions.

  • @lucycoleclough1182
    @lucycoleclough1182 10 месяцев назад

    I love python, fingers crossed that nogil implementation goes smoothly

  • @njmanga617
    @njmanga617 10 месяцев назад +1

    Thank you for the video

    • @ArjanCodes
      @ArjanCodes  10 месяцев назад

      You're welcome! :)

  • @gustavoleite8611
    @gustavoleite8611 8 месяцев назад

    I usually need keyword arguments when writing a function A that wraps another function B and I need to simply forward the arguments from A to B. But that is a very specific use case.

  • @devabdul
    @devabdul 10 месяцев назад

    I use lot of keywords arguments and type notations,❤
    I create lots of functions and sometimes i forget which type of argument it needs to pass, so i have to go back to function and read or read doc its pretty complicated so i prefer to use keywords args, notation lots, and it give a impression look 👀 code, my manager always gwt impressed with my code 😂❤

  • @GOTHICforLIFE1
    @GOTHICforLIFE1 10 месяцев назад

    I also have some hopes for a fully functional cython at some point. A python syntax language but compiled and making use of some more C features.

    • @legion_prex3650
      @legion_prex3650 10 месяцев назад

      i like cython more than mojo actually. Cython is the best choice for me. Unfortunally, does not implement 100% python, which is sad.

  • @RecursiveTriforce
    @RecursiveTriforce 10 месяцев назад +2

    0:10 In the past Python had their last version be a mathematical constant.
    1.6.1 aka φ (Golden ratio)
    2.7.18 aka e (Euler's number)
    3.14.1? aka π
    Coincidence? I think not
    Does this mean Python 4 is coming soon? Probably not

  • @acherongoon
    @acherongoon 10 месяцев назад +1

    Are immortal object immutable as implied or are the effectively a const ref. Different use-cases?

    • @ruroruro
      @ruroruro 10 месяцев назад

      I am pretty sure that he's just making stuff up. Immortal objects aren't necessarily immutable. They arguably aren't even "const ref", but more like "intentionally leaked" or "static lifetime" objects.

  • @doronvaida
    @doronvaida 10 месяцев назад

    I don't use keywords arguments, generally, trying to pass a single pydantic models between functions

  • @stonemannerie
    @stonemannerie 10 месяцев назад

    8:59 so default type vars specified with the new syntax are now covariant instead of invariant?
    EDIT: Answer: No apparently type checkers can infer it now.

  • @codecae2
    @codecae2 10 месяцев назад

    kwargs are good when using class inheritance. For instance, a constructor for a subclass is only required to declare input variables that differ from the super class. further instantiating the base class is as simple as super().__init__(**kwargs). in this way, you don't need to declare all input variables in the subclass AND the base class. Most IDEs are aware of this pattern making systems like intellisense recommend input variables for the subclass, even though they are only in the base class.

  • @brainforest88
    @brainforest88 10 месяцев назад

    Tried to subscribe to your newsletter but did not get a confirmation email. Is your service down?

  • @victornikolov537
    @victornikolov537 10 месяцев назад

    By the way, the new error messages with suggestions are so useful.
    I tried to run python -m ttkbootstrap and had an error.
    Fallowed the suggestion I changed Image.CUBIC to Image.BICUBIC somewhere in the library and that fixed it.

  • @bigutubefan2738
    @bigutubefan2738 9 месяцев назад

    Wonderful! We get amazing new interpreters. But to access them, the API is the same as exec and eval's.

  • @thecodealchemist7095
    @thecodealchemist7095 10 месяцев назад

    Anyone knows the PR for f-stringa, i have mixed reactions. This is going to invoke some chaos compared to f-strings.

  • @victornikolov537
    @victornikolov537 10 месяцев назад

    Would you cover how to dockerize a Python app?

  • @user-cl4dd3tc7w
    @user-cl4dd3tc7w 9 месяцев назад

    importerror:DLL load failed while importing _cext:The specified module could not be found, what is this error please give me solution, this occur when I import matplotlib, in python 12.00,please😭😭😭

  • @patto2k358
    @patto2k358 9 месяцев назад

    What's that keyboard, and what switches? Thanks

  • @ErikS-
    @ErikS- 10 месяцев назад

    Nested double quotes!
    Imo this deserves the nobel prize for programming!

  • @demolazer
    @demolazer 4 месяца назад

    Come to think of it, I rarely find myself using **kwargs in plain function parameters. I'll often unpack a dictionary to provide the specified arguments though.

  • @Leonardo_A1
    @Leonardo_A1 10 месяцев назад

    Hi, please could you create a Video about Mojo Programming Language with Python

  • @smftrsddvjiou6443
    @smftrsddvjiou6443 10 месяцев назад

    I never use kwargs, I use a dict if I need flexible parameter.

  • @andr3wj322
    @andr3wj322 10 месяцев назад

    Hi! I have error from the designguide email when open: PR_END_OF_FILE_ERROR

  • @sidbutcher2166
    @sidbutcher2166 9 месяцев назад

    kwargs unpacking will be useful for a big and complicated things like libraries and frameworks

  • @nicholassistovaris4632
    @nicholassistovaris4632 8 месяцев назад

    Has anyone created a class to pass arguments around ? Would you consider it ? Why and why not ?

  • @MattRose30000
    @MattRose30000 9 месяцев назад

    I always like the feature the most where it breaks all your dependencies 🥰

  • @SVGc1993
    @SVGc1993 10 месяцев назад

    I use kwargs as an argument for my GraphQL resolvers!

  • @wtfenc0reenix
    @wtfenc0reenix 10 месяцев назад

    after using typescript for years I just hoping there will be a better typing then this was python has actually. :D

  • @SaniSensei
    @SaniSensei 10 месяцев назад

    it's already that time again?
    I remember last time there was actually a live stream of the publishing, which was quite interesting, because the different core developers for various projects talked about what they did.

  • @adamstrejcovsky8257
    @adamstrejcovsky8257 10 месяцев назад

    finally there is unpack and better generics

  • @bonquaviusdingle5720
    @bonquaviusdingle5720 10 месяцев назад

    Good video 👍

  • @manishankarsingh7748
    @manishankarsingh7748 10 месяцев назад

    I use kwargs in mixins.

  • @AbuMaxime
    @AbuMaxime 10 месяцев назад

    I initially learned python about 20 years ago. A great feature of python 2, compared to C/C++ for instance, is that it didn't care much about types. It cared about interface instead, i.e it doesn't matter the type of the object, as long as it has the method foo() that the code is expecting. That made python inherently polymorphic. Trying to updating myself to python 3, I see that types are back big time nowadays. Not sure where the need for this came from.

    • @giacomo83m
      @giacomo83m 10 месяцев назад +2

      there are multiple studies (eg. monitoring projects on github) that show evidences that typing reduce runtime errors, so python but also javascript (with typescript) and php tried to introduce without enforcing this concept. So personally speaking i never had issues with lack of typing in python 2, but i guess it's very different when you have to work over large code bases that you don't really own.

    • @AbuMaxime
      @AbuMaxime 10 месяцев назад +1

      @@giacomo83m thank you

  • @fennecbesixdouze1794
    @fennecbesixdouze1794 10 месяцев назад

    @10:00 I don't understand, why do you want an infix arrow notation for lambdas? What's wrong with `lambda`?

    • @ArjanCodes
      @ArjanCodes  10 месяцев назад +1

      What I mean is that I’d like to see more readable function type annotations in Python. Instead of ‘Callable[[int], bool]’ I’d like to write something like ‘(int) => bool’.

    • @lawrencedoliveiro9104
      @lawrencedoliveiro9104 10 месяцев назад

      @@ArjanCodes That could be done if you could define your own custom operators, like “=>”.

  • @elikyals
    @elikyals 10 месяцев назад +1

    how many versions of python do you guys keep on your machines?

  • @benizakson264
    @benizakson264 10 месяцев назад

    My birthday is 3rd of December and I approve this message

  • @pdtd123
    @pdtd123 10 месяцев назад

    the design guide link is broken

  • @pissugorilla
    @pissugorilla 9 месяцев назад

    Very informative

    • @ArjanCodes
      @ArjanCodes  9 месяцев назад

      Glad it was helpful!

  • @nskeip
    @nskeip 10 месяцев назад

    The @override decorator makes Python a little bit closer to C++. That's a great sign, because the more sophisticated C++ OOP we adopt, the more programmers we need to operate Python

  • @virtualizeeverything
    @virtualizeeverything 9 месяцев назад

    I love they they are just making things better instead of adding candy

  • @skyeplus
    @skyeplus 10 месяцев назад

    Nice Scal-thon.

  • @JasonDoege
    @JasonDoege 9 месяцев назад

    Hi Arjan, I tried to sign up for your 7-step guide but your website would not accept my email address. It has a "+" in it and this tends to stymie many websites. Maybe you can fix this?
    Edit: It seems that, despite throwing an error, it sent me your guide link, anyway. Thank you!

  • @hotcrossbun26
    @hotcrossbun26 10 месяцев назад

    Lots of cool things. I agree I hate kwargs. Arrow functions no thanks though for me haha.

  • @mariof.1941
    @mariof.1941 10 месяцев назад

    Did you test Mojo too?

  • @Mempler
    @Mempler 10 месяцев назад

    That intro is really funny lmao
    Gives me 2014 vibes

  • @auroshisray9140
    @auroshisray9140 8 месяцев назад

    Good content ❤

    • @ArjanCodes
      @ArjanCodes  8 месяцев назад

      Thank you so much!

  • @AlexandrosFotiadis
    @AlexandrosFotiadis 10 месяцев назад

    I like typings in general, but a lot of people hate being specific.

  • @Luix
    @Luix 10 месяцев назад

    GIL is still there?

  • @YlmazDALKIRANscallion
    @YlmazDALKIRANscallion 9 месяцев назад

    Teşekkürler.

    • @ArjanCodes
      @ArjanCodes  9 месяцев назад +1

      Thank you so much, I appreciate your support!