Transforming Code into Beautiful, Idiomatic Python

Поділитися
Вставка
  • Опубліковано 22 гру 2024

КОМЕНТАРІ • 661

  • @rafehqazi8539
    @rafehqazi8539 9 років тому +1479

    Note to Python 3 Users:
    - izip is just zip
    - d.iteritems() is just d.items()
    - To use defaultdict: You have to do the following --> from collections import defaultdict

    • @suburbanmoscow9067
      @suburbanmoscow9067 8 років тому +12

      Rafeh Qazi thx for the additional info

    • @CleverProgrammer
      @CleverProgrammer 8 років тому +19

      Woah, did not notice my comment was sitting at 65 likes haha. I now have my own computer programming UA-cam channel! Thanks for commenting Suburban and making me see this!

    • @suburbanmoscow9067
      @suburbanmoscow9067 8 років тому +5

      You are welcome. I will check out your channel as well! Cheers

    • @javierRC82857
      @javierRC82857 8 років тому

      Rafeh Qazi but in Python 2.7 zip is an iterator? izip,zip or range,xrange why not use iterator for everything and let the programmer choose if he want expand the list?

    • @nmertsch8725
      @nmertsch8725 7 років тому +6

      Javier I'm not sure if this is what you asked for, but you can use "list(range(x))" or "list(zip(x,y))", if you really want to have a list instead of an iterable object.

  • @jeffkirchoff14
    @jeffkirchoff14 3 роки тому +8

    Man YT recommended it after 8 yrs
    In search of gold I found diamond

  • @PedroTeixeira
    @PedroTeixeira 5 років тому +34

    I’ve been using Python for over a decade (informally trained) and haven’t learned so many great tidbits so quickly in a long time. Awesome talk!

  • @juliushinze5177
    @juliushinze5177 7 років тому +170

    10:20 Beautiful syntax highlighting

    • @jonty3551
      @jonty3551 4 роки тому

      Lol

    • @frankieteardrop666
      @frankieteardrop666 4 роки тому +6

      I remember my prof for C++ and OOP had every other word/letter in his notes/code highlighted with no common theme whatsoever.

  • @merlin2600
    @merlin2600 6 років тому +32

    At 44:00, The `with ignored(OSError)` has been renamed to `with suppress(OSError)` and is from the contextlib package.

  • @qg4091
    @qg4091 8 років тому +543

    This guy is seriously amazing, love his style of teaching

    • @johncherry108
      @johncherry108 6 років тому +23

      Pity his ego needs to be continuously stroked with applause.

    • @Pulsar77
      @Pulsar77 6 років тому +43

      John Cherry Oh FFS, it's a joke. First rule of becoming a Python programmer: have a sense of humor.

    • @heinzguderian9980
      @heinzguderian9980 6 років тому +10

      He reminds me a bit too much of a pastor for me to be completely comfortable, (like from a Pentecostal church or something). Or an unctuous salesman telling us about his schemes. Material was great, though.

    • @DimitrisK5
      @DimitrisK5 5 років тому +14

      @@johncherry108 It's one of his techniques to keep the audience engaged. He is an excellent speaker and he obviously does that on purpose. You might also notice that he asks the audience all the time if they learnt something new, or how many knew that, or what's the problem with this piece of code, etc..
      On top of that, he makes me (and I assume other people, too) feel like we are part of the Python family; the core team seems close and approachable and I get a feeling of belonging to this line of developers who transformed the way we think about human programming forever.

    • @KurzedMetal
      @KurzedMetal 5 років тому +1

      No wonder why Python is awesome, they have awesome devs :)

  • @brotherlui5956
    @brotherlui5956 5 років тому +55

    6 years old but still good advice. Raymond is a great teacher.

    • @anon_genz
      @anon_genz Рік тому +1

      @@kolterdyx 10 years old, your statement of his statement still stands.

    • @stijnvandensande3579
      @stijnvandensande3579 11 місяців тому

      @@anon_genz almost 11 now

    • @anon_genz
      @anon_genz 11 місяців тому

      @@stijnvandensande3579 • and still holds up

  • @kumarc634
    @kumarc634 9 років тому +427

    at 7:22 it should not
    for i, color in enumerate(colors):
    print i,'--->',color[i]
    but
    for i, color in enumerate(colors):
    print i,'--->',color
    may be printing mistake

    • @mByyurt
      @mByyurt 7 років тому +45

      I was here to write that. Nice catch.

    • @a8lg6p
      @a8lg6p 7 років тому +37

      I was about to make that comment. Either way works the same, but it's exactly what he's been telling us not to do, so clearly a mistake.

    • @adelkhafizova
      @adelkhafizova 7 років тому +30

      Also stopped the video to see if someone has pointed this out already)

    • @aikimark1955
      @aikimark1955 7 років тому +1

      Do you think that Raymond is reading these comments?

    • @EyeIn_The_Sky
      @EyeIn_The_Sky 7 років тому

      I think you do have to have the: print(i,'-->', color [i]) otherwise you will just get all the colours beside each index in a row repeated 4 times. Unless this is just in Python 3?

  • @Achrononmaster
    @Achrononmaster 5 років тому +104

    The ignored() idiom exists in Python 3.4+ but is called suppress():
    # NEW WAY in Python 3.4+:
    from contextlib import suppress
    with suppress(OSError):
    os.remove('foo.txt')

    • @locanix
      @locanix 4 роки тому

      Thanks! I was wondering why I couldn't find it

    • @rusca8
      @rusca8 3 роки тому

      +

  • @thatguy1000001
    @thatguy1000001 10 років тому +16

    I literally just watched this a second time for the entertainment value! Raymond Hettinger is hilarious! Not only was watching this a lot of fun, but super-informative and efficient.
    I'm going to go check out some of his other talks. If I'm gonna learn python, it might as well be from this dude!

    • @tdao9741
      @tdao9741 3 роки тому +1

      And how’s yours python 7 years later?

  • @gromilla1990
    @gromilla1990 7 років тому +131

    "If you are mutating something while you are iterating over it, you are living in a state of sin and you deserve whatever happens to you" :D loled so hard on this one! 20:20

    • @Michael-jq1hl
      @Michael-jq1hl 4 роки тому

      Hi I have recently started studying python, what is that arrow in print i,'-->',color?

    • @burakozdamar
      @burakozdamar 4 роки тому +3

      ​@@Michael-jq1hl it's not a special character or something. he just wanted to print an arrow, that's it. the characters in single or double quotation marks are interpreted as string. so this statement prints 1 --> greens for example.

    • @Michael-jq1hl
      @Michael-jq1hl 4 роки тому

      @@burakozdamar I see, many thanks, I never found the answer to that and now that I see the quotes makes more sense :)

    • @godfather7339
      @godfather7339 3 роки тому

      @@Michael-jq1hl it's been a year, hope you are doing with python.

    • @Michael-jq1hl
      @Michael-jq1hl 3 роки тому

      @@godfather7339 hey, kind of. I decided that instead of developing I could recruit Python Devs, so that is how I am using the little skill I have acquired.
      Unfortunately, most Devs think I am like any other recruiter and ignore me xD

  • @torgeirlaurvik8195
    @torgeirlaurvik8195 4 роки тому +1

    This video was the video that got me interested in writing ideomatic Python and iterators. I've revisited it now and then ever since 1. year at uni. Amazing lecturer.

  • @guhkunpatata3150
    @guhkunpatata3150 2 роки тому

    Where have I been All this time only to find this GEM right now ??? This video is very great and a MUST WATCH for any pythonista

  • @Krazness
    @Krazness 7 років тому +2

    this may be the best python video I've seen online

    • @bonbonpony
      @bonbonpony 6 років тому

      Yeah, there should be a video like this one for every language out there.
      One can learn much more about how to write clean code from such videos than from any crappy tutorial.

  • @stasbovanenko
    @stasbovanenko 5 років тому +1

    Amazing talk ! Probably best I've heard in all 26 year I'm coding. A handful of smiles and headful of HQ knowledge. Thank you, Raymond !

  • @jnuxadrian
    @jnuxadrian 10 років тому +39

    I think that 'return newfunc(*args)' on line 6 must be replaced by 'return saved[args]' at 41:12

  • @77aHeB
    @77aHeB 2 роки тому +2

    First - this is an awesome piece, I didn't knew Raymond Hettinger was to be blamed for so many iterators in python, and I truthfully love this guy now that I know what he did for most of my days! :)
    There is a small bug in 15:58 onwards due to the missing tgt variable, but the more important thing is that it can get even more beautiful (IMHO) from:
    def find(seq, target):
    for i, value in enumerate(seq):
    if value == target:
    break
    else:
    return -1
    return i
    to this:
    def find(seq, target):
    for i, value in enumerate(seq):
    if value == target:
    return i
    return -1
    not that the for/else is not nice in some other cases, this was probably just not the right example for it.

  • @shushens
    @shushens 10 років тому +19

    Love this guy. I was quite disappointed when it ended. I was so expecting a much much longer video :D

    • @ceestimmerman9785
      @ceestimmerman9785 7 років тому

      You could read the "What's New" articles instead: docs.python.org/3/whatsnew/index.html

    • @jacobschmidt
      @jacobschmidt 4 роки тому +1

      @@ceestimmerman9785 it's not quite the same!

  • @toomuchtruth
    @toomuchtruth 7 років тому +1

    "Start open source contributions to project by going in and placing doc strings". This is a brilliant idea! I've wanted to start contributing for so long but didn't feel I have the skills, I'm gonna do this!!!

    • @bonbonpony
      @bonbonpony 6 років тому

      Yes, do it. There's a lot of extremely crappy documentation for Python modules :q

  • @MrCoolnamehuh
    @MrCoolnamehuh 11 років тому +1

    Found this to be one of the most useful python talks thus yet on youtube.

  • @richieKostenko
    @richieKostenko 10 років тому +4

    This is probably the best presented programming video I've ever seen. Thanks!

  • @caballerofelipe00
    @caballerofelipe00 4 роки тому

    I didn't read all comments but I fount that in 29:12 there is an error, 'namespace = parser.parse_args([])' should not contain an empty array as argument, that way it doesn't take into consideration CLI arguments.

  • @sandeshgowdru8869
    @sandeshgowdru8869 Рік тому +1

    10 years old video, and it is gold.

    • @chrstfer2452
      @chrstfer2452 Рік тому

      Some minor differences, izip is just zip now i guess

  • @MrTigerstyle80
    @MrTigerstyle80 9 років тому +10

    This dude is off the hook smart.

  • @matthewwatts9693
    @matthewwatts9693 10 років тому +11

    This is a must see video for an python developer. Fantastic!

  • @borgonzalezusach9263
    @borgonzalezusach9263 10 років тому

    This man is technically brilliant and hilarious. Not something you see everyday. Thanks for the nice speech!!

  • @VladimirSanchez
    @VladimirSanchez 11 років тому +2

    I can listen to Mr Hettinger all the time!!!
    Thanks for the presentation and your contributions.

  • @orkoxy
    @orkoxy 10 років тому +19

    At 7:26, it should be
    for i, color in enumerate(colors):
    print i, '-->', color

    • @Michael-jq1hl
      @Michael-jq1hl 4 роки тому +2

      Hi I have recently started studying python, what is that arrow in print i,'-->',color?

    • @2adamast
      @2adamast 4 роки тому

      Michael the arrow is a string

  • @MrTigerstyle80
    @MrTigerstyle80 6 років тому +3

    Dude’s kind of a colossal badass. Not even mad at the Casey Kasem vibe at all. He’s a beast.

  • @joedempseysr.3376
    @joedempseysr.3376 6 років тому

    I thoroughly enjoyed your presentation! Take the old-fashioned, ugly, slow way of doing things and instead do the new-fangled, beautiful, fast way. I love it!

  • @BillTubbs
    @BillTubbs 9 років тому +25

    There's an error on the slide at 7:13 titled 'Looping over a collection and indices'. Last line should be:
    print i, '-->', color

    • @vanshdeep91
      @vanshdeep91 8 років тому

      Bill Tubbs both have the same meaning brother be it color or colors [i]

    • @BillTubbs
      @BillTubbs 8 років тому +4

      Both have the same result but using the color iterator that enumerate creates is 'faster and beautiful' as he points out.

  • @eos_rf
    @eos_rf 4 роки тому +2

    15:59
    *if value == tgt*
    is undefined, maybe "target"?

  • @anAlokDubey
    @anAlokDubey 3 роки тому

    I m watching 7 years old video and leaning lots of amazing things.... :-) you are really great.

  • @hoanghaipham4318
    @hoanghaipham4318 3 роки тому +1

    What amazing techniques! Why I haven't seen this sooner. Thank you a lots

  • @CraigPerry
    @CraigPerry 11 років тому +1

    Raymond's an entertaining, engaging presenter. Good mix of material here, definitely came away richer for the experience.

  • @Decessus117
    @Decessus117 9 років тому +247

    "There's two kinds of people in the world: people who've mastered dictionaries and total goobers." - Raymond Hettinger

  • @RomanDryndik
    @RomanDryndik 7 років тому +16

    At 41:09 when he explains self-defined defined decorator for LRU cache it has an error. His implementation leads to infinite recursion.
    Instead of this:
    def cache(func):
    saved = {}
    def newfunc(*args):
    if args in saved:
    return newfunc(*args)
    result = func(*args)
    saved[args] = result
    return result
    return newfunc
    It should've been:
    def cache(func):
    saved = {}
    def newfunc(*args):
    if args in saved:
    return saved[args]
    result = func(*args)
    saved[args] = result
    return result
    return newfunc

    • @TheAnimystro
      @TheAnimystro 5 років тому

      Thanks, I was staring at the code confused as to how that could possibly work, because I assumed he was right and I was missing something!

    • @mikhaill244
      @mikhaill244 2 роки тому

      Also pointed out that something wrong with the code. Ran it, and yes, infinite recursion.

  • @DmitriiGlandarius
    @DmitriiGlandarius 8 років тому +16

    Very nice. In just 50 minutes I learned moe then in the last month.

  • @mpgovinda
    @mpgovinda 5 років тому

    Just one video and learned more things worth years... great tips!

  • @JamesSKim
    @JamesSKim 11 років тому +3

    This lecture is very nice to learn advanced Python programming. After I watched this video, I realize that I have used Python almost like using C. I have used C and C++ as well as Matlab. Hence, I thought that many approaches in Python will be not much different from the conventional languages except specialized keywords. However, I realize that grammars in Python can be different from that in C.

  • @cygil1
    @cygil1 5 років тому +1

    @14:21 lambda: f.read(32) is a lot clearer to me than "partial(f.read, 32)" since all we're actually doing is suppressing evaluation of f.read until it's called by iter, the equivalent of quoting in lisp. It threw me for a loop because I think of partial as being used for partial evaluation, something to do with the name I think.

  • @bloody_albatross
    @bloody_albatross 10 років тому +1

    27:50 I think doing this is so common, there should be a group_by(sequence, keyfunc). You could then call it with group_by(names, len). There should also be an index_by(sequence, keyfunc). These functions would be trivial to implement, but nevertheless they are common and useful enough to be put in some standard lib (collections?).

  • @Algoritmik
    @Algoritmik Рік тому +1

    At 07:30, the 2nd line of the 2nd for loop should be:
    print i, '->', color # not colors[i] !

  • @derekeden1163
    @derekeden1163 5 років тому

    probably best python video ive ever seen

  • @mountainhobo
    @mountainhobo 11 років тому +11

    Love Raymond's presentation style.

  • @martinborus9531
    @martinborus9531 Рік тому

    This talk is great even after 10 years.
    Some of the syntax has changed, for example in 2023:
    at 44:05 the "with ignored" is now
    from contextlib import suppress
    with suppress(OSERROR):
    and the "izip" command is gone, zip now creates a generator.

  • @andik70
    @andik70 7 років тому +2

    7:13 isnt the enumerate example 'wrong'. Shouldnt colors[i] be replaced by color?

  • @SvenSiegmund
    @SvenSiegmund 10 років тому +1

    I love the people who make Python! Thanks for this most enlightening talk.

  • @t0919766755
    @t0919766755 6 років тому

    @41:14 cache function should return saved[args] when args is in saved dict

  • @DeMurker
    @DeMurker 9 років тому +5

    Great explanations. And even 3 years late still very useful.
    One thing though, he says that generator expressions make things faster but when I timeit I get this:
    ~$ python -m timeit "sum(i**2 for i in xrange(10))"
    100000 loops, best of 3: 1.74 usec per loop
    ~$ python -m timeit "sum([i**2 for i in xrange(10)])"
    1000000 loops, best of 3: 1.39 usec per loop

    • @benburrill
      @benburrill 8 років тому +5

      +DeMurker Not reproducible: I got 2.57 for generator and 2.77 for list. But in any case, as you go beyond a 10 element list, you are going to get increasingly large memory and speed problems.

    • @Shaddycls
      @Shaddycls 8 років тому +1

      The reason beyond containers over generators affects only at memory level: using zip(iterator1, iterator2) produces a single big object which contains the sum of both containers, since when you use a generator, it only produces an element on each iteration, so you will never have the entire sum of both containers in memory, which is an optimization and faster.

    • @deidyomega
      @deidyomega 7 років тому +1

      Do it again, but xrange(1000000) ;-)

  • @jakykong
    @jakykong 4 роки тому +4

    He even said I would fight him on this, but haha, oh man, the comparison functions are something I absolutely *miss*, even if I really agree with almost everything else he said and have been writing idiomatic Python for ages. I ran into a real problem the other day where comparisons were a much cleaner solution than the less obvious and potentially much slower multi-pass sorting: Sorting on multiple keys with independent ascending or descending orders.
    You can sort a plain tuple without any fuss if you don't mind that every key is ascending or every key is descending. But if you want to mix those, you have to do it in multiple passes, starting from the least significant key to the most significant key, and rely on timsort's stability to get the job done -- or, IMO, cleaner -- if this were Python 2, I could have expressed the comparison function with appropriate ascending/descending signs in a simple if/elif/else return 0 chain, and rapidly expressed both the intent and the functional result quickly.
    Python 3 even provides a conversion utility that creates wrapper objects on the fly to facilitate this need, which is a bizarrely convoluted way to accomplish what simply allowing either key function or comparison function would have.

  • @anubhav9476
    @anubhav9476 4 роки тому +1

    Man even though this is not quite as relevant to me today, I really love his presentation style

  • @VibeWithSingh
    @VibeWithSingh 8 років тому +6

    This presentation is simply awesome !! hands down !!

  • @espeon91
    @espeon91 9 років тому

    Really insightful video. Didn't even notice the time fly by. Already feel better as a Python programmer.

  • @snowblindu
    @snowblindu 9 років тому +280

    I wish this guy was my teacher

    • @hdggoyo7423
      @hdggoyo7423 9 років тому +2

      +snowblindu he's cocky and not interesting at all

    • @PhilGerb93
      @PhilGerb93 9 років тому +17

      +hd ggoyo pffft, hater. I wish he was my teacher too!

    • @jfolz
      @jfolz 8 років тому +42

      +hd ggoyo He added a lot of the cool stuff to Python so he gets to be cocky.

    • @hdggoyo7423
      @hdggoyo7423 8 років тому +6

      +riDDimann i was just joking, he looks like a cool dude, chill guys

    • @AlfredEssa
      @AlfredEssa 7 років тому +7

      He is cocky, but he knows his shit. If you are going to be a hater, prove your chops.

  • @mattralston4969
    @mattralston4969 4 роки тому +1

    Thank you for the lecture, sir. I appreciate the review of some critical "dos and don'ts" for beginners.

  • @TheGIXL
    @TheGIXL 5 років тому +7

    41:16 it should be "return saved[args]" instead of "return newfunc(*args)"

  • @gibbostooth
    @gibbostooth 6 років тому

    43:47 "ignored" is now called "suppress" and it's part of "contextlib" library.

  • @darkopz
    @darkopz 6 років тому +2

    Initially I refuse to believe any developer wouldn’t know what “in” semantically means, but then I’m reminded of all the code I’ve seen.

    • @bonbonpony
      @bonbonpony 6 років тому +3

      Most programmers nowadays have just learnt to parrot other people's code without any actual in-depth understanding of what it does or why is its syntax the way it is. Mostly "thanks to" online tutorials, like those on Udemy or alike where blind lead the blind :q I still have people giving me weird looks when I write C++ code like this:
      if (a == b) do_something();
      else do_something_else();
      instead of wrapping the functions into braces, because they think that those braces are part of the syntaxt and have to be there. Or if I write something like this:
      cout

  • @vineetbhargava4141
    @vineetbhargava4141 5 місяців тому

    At 41:09 - in the cache decorator definition - line 6: if we return newfunc(*args) wouldn't it cause infinite calls?

  • @MrHatoi
    @MrHatoi 5 років тому +2

    7:30 Shouldn't you be using "color" instead of "colors[i]" in the second one?

  • @franzweitkamp
    @franzweitkamp 7 років тому +1

    @18:35 , why not replace the break statement with return i, get rid of break and else and put return-1 one indentation to the left?

    • @bonbonpony
      @bonbonpony 6 років тому

      I can think of one "why": you want to do some extra stuff after the loop with that found element.

  • @zachariaskoutsokostas7613
    @zachariaskoutsokostas7613 3 роки тому

    15:50, can we argue that is no surprising the [for..else ] loop to be shocking for devs who see it for the first time? It might have even made sense to be the other way around? That is "for x in z" (translated to I am going to iterate over all these elements) or "else" (execute smth if unable to do so). That would be an "else" line tight to the "for" line. Furthermore, we might never have a conditional exit inside the body of the "for", and expect to finish the loop. Then else to what?

  • @MacroAggressor
    @MacroAggressor 5 років тому +1

    This is great! I have a *much* better understanding of iterators and their purpose now. Thanks, Mr. Hettinger.
    edit: How did I not know about dictionary comprehensions?!? (21:05) That is AWESOME!!

    • @dgh25
      @dgh25 Рік тому

      idk, kinda standard stuff in CS

  • @AGT0M
    @AGT0M 5 років тому +1

    Thanks for sharing.
    I'm new to Python, but I wonder if all the presented snippets of code have been tested. For example, at around 16:00 the code would most likely blow up with an undefined error for tgt, as the input argument named different - target, but all-in-all - good stuff.

    • @ewerybody
      @ewerybody 4 роки тому

      yeah not many people found that one! 👏

  • @Achrononmaster
    @Achrononmaster 5 років тому +1

    izip() in Python2 is zip() in Python3. Also, you can loop over the longer of the lists. So,
    import itertools
    colors = ['red','green,'blue','purple']; shapes =['circle,'triangle','square']
    for col, shp in zip_longest(colors,shapes):
    print( col, '--->', shp)
    >>>
    red ---> circle
    green ---> triangle
    blue ---> square

  • @yuli3873
    @yuli3873 3 роки тому +1

    So this man made enumerate()? I love him from now on!

  • @jasonstapley6822
    @jasonstapley6822 6 років тому

    That talk was amazing. Will need to watch this video a few times.

  • @TomLeg
    @TomLeg 3 роки тому

    @16:08 => Your parameter is 'target' but then you compare value to 'tgt'

  • @eduardoherrera3696
    @eduardoherrera3696 5 років тому

    Thank you so much for this wonderful lecture. I think this insight might be helpful . As a Novice programer I had a few issues understanding how some of core functions in Python worked and what was because the people who taught me where using derived language examples. Phrases like "if you've code an another language....". But I haven't well time passed I learned the hard way later got to this video and inevitably think that things would been a lot easier for me if this lecture was around.

  • @isilanes
    @isilanes 10 років тому

    24:20, about the use of get() when counting appearances of color within a list. I am probably not saying anything new, but I did some tests and actually using get() is slower than the naïve "if color not in d". More concise, sure, but more efficient... it doesn't seem so. The defaultdict he mentions later is actually quite faster, even including the time to convert the defaultdict back into a regular dict.
    Of the alternative ways of doing the counting, I sometimes use a fourth one he doesn't mention, and is almost as fast as the defaultdict. The code would go like this:
    d = {}
    for color in colors:
    try:
    d[color] += 1
    except:
    d[color] = 1
    Of course the relative speed of different methods depends on how many different "color" items we have within the list "colors". The try/except method is more efficient the less distinct colors there are (so less except blocks executed).

  • @miguelvasquez9849
    @miguelvasquez9849 Рік тому

    this is why i love python, the ways to write clean code.

  • @purplecrayon7281
    @purplecrayon7281 2 роки тому

    I love this man! He should write a book on clean Python code, if he hasn't already.

  • @strafeae4618
    @strafeae4618 7 років тому

    At 7:15 wouldn't it make more sense to use color instead of colors[i] since you're trying to get away from the whole "using indicies" thing?

  • @TheVoitel
    @TheVoitel 4 роки тому +4

    7:18
    for i, color in enumerate(colors):
    print i, '-->', colors[i]
    is an example of the dangers of copy and paste, just saying ...

    • @happygimp0
      @happygimp0 4 роки тому

      Not his only error, he also used target and then tgt. He didn't test his code, which is a bad sign.

    • @TheVoitel
      @TheVoitel 4 роки тому

      @@happygimp0 Yes, but that’s typo you will notice when testing.
      The other one you will not notice, but he is doing the same thing again, when he wanted to do a more elegant solution.
      So the mistake lies in the very thing he wants to showcase.

    • @Avandale0
      @Avandale0 4 роки тому

      nicely spotted

    • @deViant14
      @deViant14 3 роки тому

      @@happygimp0 bad sign? It appears he wrote roughly half of what was new in Python 3.

  • @BryanChance
    @BryanChance 3 роки тому +1

    Amazing talk..more professors like him. :) I'm starting to appreciate Python now.
    EDIT: Wow

  • @mingosutu
    @mingosutu 4 роки тому +8

    In python you make your video with audience, clapping, laughing and commenting. Python is fantastic.

  • @matiasherranz86
    @matiasherranz86 3 роки тому

    After over 10 years as a working professionally with Python, Hettinger can still blow my mind and renew my passion towards the language. Anyone knows if the deck of slides is still available anywhere?

    • @youliyav
      @youliyav 3 роки тому +1

      Slides: speakerdeck.com/pyconslides/transforming-code-into-beautiful-idiomatic-python-by-raymond-hettinger-1

    • @matiasherranz86
      @matiasherranz86 3 роки тому

      @@youliyav Nice!! Thanks!

  • @snooks5607
    @snooks5607 5 років тому +2

    18:18 it's actually easy to read that as an indentation error. someone might "fix" the code by indenting the else inside the for :|

  • @HenrikVendelbo
    @HenrikVendelbo 8 років тому +1

    7:23 minor slide bug for the print statement in the enumerate version, might just print color instead of colors[i]

    • @Michael-jq1hl
      @Michael-jq1hl 4 роки тому

      Hi I have recently started studying python, what is that arrow in print i,'-->',color?

  • @RiptheJacker
    @RiptheJacker 10 років тому

    Really good video. Starts off as a video for python beginners but is insightful for experienced developers as well.

  • @rdoetjes
    @rdoetjes 11 років тому +9

    I learned a lot! Then again I don't use Py3 because I use Jython which only 2.7 is stable and a compositing suite that has 2.7 also.
    The problem with functional programming is (and this video proves it) is that you need to know the function names and what to look for. This means actually bothering to read lots of papers and documentation and then you need to remember them. People aren't very good in remembering things especially non-descriptive.
    So only people who really dedicated in a language will know these things but Python is an awesome language but it's not a core programming language for most. Which is Java, C# or C++ and there you don't have a lot of functional functions.
    I love C because it has very few keywords, STL is great but I ALWAYS need to to reread who it works. Functionally very powerful but it's even less descriptive than these functions.
    So now that I know these situations explained by Raymond I will look them back here and read the docs apply them several times and probably by the 7th or 9th time I will remember it. That is until I don't use Python for 2 years again and forgotten all about them :D

    • @palpytine
      @palpytine 6 років тому +1

      Many (if not most) FP languages offer some sort of modules or namespaces to handle this exact problem of discovery, it's definitely not an issue with the paradigm in general.

  • @wabalrarrt9374
    @wabalrarrt9374 Місяць тому

    I want to see new updated version of this video

  • @kychemclass5850
    @kychemclass5850 2 роки тому

    Re: 5:15 how did you get away with using a print statement that didn't encase the variable in () ??

  • @uthoshantm
    @uthoshantm 5 років тому +1

    Note that these functional constructs are now in every mainstream language such as C# and Java. So, it's not that Python has a specific capability, but experienced Python programmers do encourage the use functional constructs. This video is an example.

  • @wenflybywind572
    @wenflybywind572 10 років тому +6

    I think in cache decorator, `if args in saved`, there should return `saved[args]`

    • @BrianZhangOfficial
      @BrianZhangOfficial 8 років тому +2

      +Wen Flybywind thanks, thought I was going crazy for a second

    • @worldwidetraveler3730
      @worldwidetraveler3730 5 років тому

      Thanks - I am totally new to Python and was certain I would never spot an error - but looks like Idid

  • @manojbisht7018
    @manojbisht7018 8 років тому +49

    Documented version gist.github.com/JeffPaine/6213790

  • @MrWorshipMe
    @MrWorshipMe 6 років тому +5

    Whenever you have a break in the for loop, just wrap that loop inside a function and return instead of break. If you want to return something else in case the for loop didn't break, just return after that loop. No need for else on the for. A for loop with a break and an else is not as readable as a function which just returns from the loop and after it.

    • @bonbonpony
      @bonbonpony 6 років тому +1

      Agreed. However it's not always that easy. For example, if you rely on a lot of state variables inside a complex loop: although factoring it into a function would seem as a great thing to have, it would also mean that you would have to find some way to carry on all that complicated context along with it :q

    • @MrWorshipMe
      @MrWorshipMe 6 років тому

      @@bonbonpony This is exactly what classes are for. Encapsulate all that context inside one class, and have that for loop as a private function.
      Or if that context is shared, have it inside a named tuple and pass it to the function.

    • @bonbonpony
      @bonbonpony 6 років тому

      But that's the problem: then you have to PASS it around all the time.
      And it's not that _all_ of that context is needed _all_ the time. Suppose the loop uses only 50% of it. Then you have to pass the other unneeded 50% of the clutter too. And it will be a mess. (Inb4 you say passing objects is cheap by reference: but it's still a mess.)
      Classes? No, that's not what classes are for. Classes are not just "big ol' bags for data and functions" (unfortunately, many people think of them that way.) They are means to model real-life objects as new data types, by defining their interfaces. What you meant is more like a _namespace_ or _module_ , but still it doesn't solve the problem - it just moves it somewhere else. Because all that state will now have to be shared between several functions and, as I said, not _every_ function requires _every_ piece of that state at the same time.

  • @balthazarfitzpatrick7770
    @balthazarfitzpatrick7770 4 роки тому

    shouldn't the pythonic way at 07:30 be "for i, color in enumerate(colors): print i, '-->', color" instead of "[...] i, '-->', colors[i]"?

  • @joseville
    @joseville 4 роки тому

    17:00
    Let A = "the loop ran over a non-empty iterable and there was A break"
    Let B = "the loop ran over a non-empty iterable and there was NO break"
    Let C = "the loop ran over an empty iterable" (i.e. there were no iterations)
    The `else` in `for... else` runs in cases B and C. I need something that runs only in case C. I don't think there is such a thing. If there were, maybe it could be called `emptyloop` or `empty`.
    A bit of a contrived example:
    ```
    # `node` is a BST node
    for child in (node.left, node.right):
    process(child)
    empty:
    print(f"{node} is a leaf node")
    ```

  • @tc14hd23
    @tc14hd23 2 роки тому +1

    40:57 Does someone know what a "pal function" is? Edit: Oh, I guess he means pow()

  • @TOn-fx2gr
    @TOn-fx2gr 4 роки тому

    Can someone explain to me why in 18:40 we cant just do like this :
    Def find (seq,target):
    for i , value in enumerate (seq) :
    If value == tgt :
    Return i
    return -1
    Why the way he did it is better ,or its just an example to show the for else .... ?

  • @PramodL
    @PramodL 11 років тому

    Can't recommend this talk enough. Must watch to take your python chops to the next level.

  • @movax20h
    @movax20h 5 років тому +1

    "with ignored(OSError)". So cool. TIL. In Python 3, it is called "with suppress(...)". You can list multiple exception types too.

  • @bloody_albatross
    @bloody_albatross 10 років тому +10

    Also I would simplify the code at 13:00 to this (one liner!):
    blocks = list(iter(partial(f.read, 32), ''))

    • @heraldo623
      @heraldo623 5 років тому

      Functional programming

  • @sudiptochatterjee
    @sudiptochatterjee 7 років тому

    Thanks a lot for this video. Raymond is an awesome guy.

  • @nishankbani3257
    @nishankbani3257 7 років тому

    Excellent presentation on Python code writing.

  • @jerryliang5605
    @jerryliang5605 3 роки тому

    At 7:22, why not "print i, '-->', color" ?

  • @kelbiekelbie909
    @kelbiekelbie909 7 років тому +6

    7:11 Shouldnt it be
    for i, color in colors:
    print(i, color)

  • @anonvigil628
    @anonvigil628 5 років тому +1

    This needs updated for Python 3 - I have to go hunting for which of his recommendations are still valid. The video could at least have footnotes that say which still applies in Py3.