Quick Python Refactoring Tips

Поделиться
HTML-код
  • Опубликовано: 27 янв 2025

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

  • @patloeber
    @patloeber  3 года назад +9

    I hope you like those tips! If you want to install the Refactoring Extension in VS Code or PyCharm, you can check it out here: sourcery.ai/? *
    ----------------------------------------------------------------------------------------------------------
    * This is an affiliate link. By clicking on it you will not have any additional costs, instead you will support me and my project. Thank you! 🙏

  • @Mutual_Information
    @Mutual_Information 3 года назад +2

    Really high information density on these vids. Very nice and not often seen.

  • @adrien.cordonnier
    @adrien.cordonnier 3 года назад +8

    3:35 Tip #5 can be applied one more time. You can avoid the "else:" and corresponding indentation as you just returned in the previous if section.

    • @patloeber
      @patloeber  3 года назад

      yep thanks for the hint!

  • @sourg_rage
    @sourg_rage 3 года назад +73

    Good tips, thanks! Personally, I don't like returning an expression directly without assigning to a variable. When you use a variable, it is easy to add a breakpoint without refactoring if you need to see the value before it is returned.

    • @patloeber
      @patloeber  3 года назад +11

      Good point! Yes this point is debatable, too :) I also like to use the variable in certain cases

    • @aleksandarandjelkovic8650
      @aleksandarandjelkovic8650 3 года назад +7

      It is as easy to add a breakpoint to a return statement even without a variable and evaluate the expression in a debugger, at least in a decent IDE. I don't think adding variables just for that is approved. Readability, on the other hand, is discussable.

    • @dennycrane2938
      @dennycrane2938 Год назад +1

      I can to make the same comment. It's easier for debugging

  • @FORGIVE123N
    @FORGIVE123N 3 года назад

    Thanks a lot! Tips about "any" statement, assigning variables closer to their usage and guard statements to remove excessive indentation were very nice.

  • @henryantwi8222
    @henryantwi8222 Год назад

    Thanks for these helpful tips. I'll start using them asap

  • @thatoneuser8600
    @thatoneuser8600 3 года назад +1

    3:50 you can also inline the current_fashion local variable and rename the getter method, as well as getting rid of the else statement as the second if statement can also serve as a quasi-guard clause

  • @emi3955
    @emi3955 2 года назад

    Great advice, did not know "any" . Thanks a lot

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

    Nice! I didn't think of some of these, good tips.

  • @meowvee
    @meowvee 3 года назад +21

    #4: `var=something; return var` has its place: debugging.

  • @manojm9084
    @manojm9084 2 года назад

    Thirst for learning . This channel is a good one to quench

  • @helovesdata8483
    @helovesdata8483 2 года назад +1

    I'm trying to become a data engineer and Python is my first coding language. My goal is to improve my programming skills and this video is super helpful to me.

  • @CodingIsFun
    @CodingIsFun 3 года назад +5

    Hi Patrick,
    Great video as always! Thanks for sharing your knowledge!
    Also, your new Website design is outstanding. 👍
    Beste Gruesse,
    Sven

    • @patloeber
      @patloeber  3 года назад +2

      Thank you! Just noticed you have a channel, too. Great work :)

  • @anneest
    @anneest 3 года назад

    Thanks for those tips, they are great! I have been refactoring a lot of my code lately, guess it shows I am progressing 😀 So refactoring tips: YES PLEASE! Great vid format as well 👍

  • @Yotanido
    @Yotanido 3 года назад +26

    3:57 I actually disagree with this one.
    Just checking the truthy-ness of a list is not always what you want. None is also falsy and is also recommended to be checked like this. What if you have a list that might be None? You now can't tell apart None and the empty list.
    Or, what if you have a list that shouldn't be None? If a None value makes it into your function somehow, it will be treated as if it were an empty list. It should just throw an exception instead, being given an invalid value.
    I always use "is None" and "len(x) == 0" checks to make it clear what exactly I am checking.

    • @patloeber
      @patloeber  3 года назад +6

      fair point! Checking for None and falsy can indeed be a pitfall in certain cases. I should have pointed this out...

    • @MaZe741
      @MaZe741 3 года назад

      if you have a list thats "None" then you dont have a list, why would you design your code like that?

    • @TheJacklwilliams
      @TheJacklwilliams 3 года назад

      @@patloeber Yeah I gotta jump in here with Random... To you and Yndostrul, from a newb, when will I have a list that is None? A little lost, even a simple example would help if you have a moment...

    • @dl662
      @dl662 3 года назад +3

      @@TheJacklwilliams random's argument is not very pythonic. more often than not we would want to default a list variable to None instead of [] bc how python evaluates its default arguments (e.g. def func(a_list=None)). It's very common to have a list that's None; and in this case, if we want to treat None and [] the same in a single condition, it's perfectly fine to write "if a_list:"; but if None and [] deserves their own case we would wanna be more explicit about checking "len(a_list) == 0" for the [] value.

    • @TheJacklwilliams
      @TheJacklwilliams 3 года назад +3

      @@dl662 Thanks Derek. I’m a complete newb and doing all I can to start out with good habits. Being pythonic and doing things in an optimum fashion are top of mind for me. I appreciate the explanation. Thank you.

  • @estevaoyt
    @estevaoyt 2 года назад

    Python Engineer, you are amazing!

  • @michealhall7776
    @michealhall7776 3 года назад +5

    Update: any(generator) --> Stops at the first true result of the generator, without processing the rest. Which is very useful and something I'm glad I now know
    Original comment:
    Can someone run that any( check
    I believe the whole generator is first evaluated then any checks the result.
    If so this is not what you want on most large datasets

  • @michealhall7776
    @michealhall7776 3 года назад +1

    I prefer to only have return per function, it's much cleaner and easier to debug.
    Returning results as the var IMO is best practice. It allows you to easily debug and read the code
    output = 'hello' * 2
    return output #> 'hellohello'
    That advice is only true when dealing with large numpy arrays where creating the variable is time consuming.

  • @ChrisHalden007
    @ChrisHalden007 3 года назад

    Great tips. Thanks

  • @bobsalita3417
    @bobsalita3417 3 года назад

    Well balanced information. Concise. Thanks.

  • @AlphaWatt
    @AlphaWatt 3 года назад

    Excellent video. Thanks!

    • @patloeber
      @patloeber  3 года назад

      thanks for watching :)

  • @Param3021
    @Param3021 3 года назад

    Thanks for the 8th tip, it is useful.
    Actually, your all tips are great and useful, Nice tips

    • @patloeber
      @patloeber  3 года назад +1

      Glad it was helpful!

  • @bryandata6658
    @bryandata6658 19 дней назад

    Definitely prefer a simple if-expression over an if statement for a simple assignment.

  • @TMQuest
    @TMQuest 3 года назад +1

    For number 5 (if expressions), then I think the if expressions can simplify code assuming that the code is not too long. For your example, I think that the shortening does not make it less readable. However, for if-else statements with longer assignments and conditions, the shorthand if expression can make the readability go way down (this is the same problem that long list comprehensions have). There is also the disadvantage that programmers from other languages can find the syntax a bit weird (although ternary operators still exist in e.g. JavaScript).
    I've purposefully avoided using the if expressions in my videos since I am not sure that everything knows about them. However, I think it would be good if more people knew :)

  • @quixzotic
    @quixzotic 3 года назад +1

    Love the new video! 🔥

  • @nano7586
    @nano7586 2 года назад

    I have no idea why but I have always been doing these 8 things. I'm not even a good programmer but I guess a lot of trial & error gives you a bit of intuition about what seems more readable.

  • @alex_linhares
    @alex_linhares 3 года назад

    Nice. Subscribed!

  • @georgethornburg9259
    @georgethornburg9259 3 года назад

    Patrick, just subscribed too your channel. Love your work. I waa trying to find out where you're from. You sound Canadian ie Letterkenney vibe.

    • @patloeber
      @patloeber  3 года назад

      Haha thank you so much! I am German ;)

  •  3 года назад

    these are true for any language, but good tips indeed

  • @jagjitsinghramgarhia4766
    @jagjitsinghramgarhia4766 3 года назад

    I write nested if expressions and have written a nested list comprehension which was 3-4 levels deep, can't even debug it anymore, it just works and no one knows why now.

    • @lepidoptera9337
      @lepidoptera9337 3 года назад

      Why would you want to touch it, if it works? Unless you need to change it to accommodate new functionality, in which case it's better to rewrite it from scratch, leave it alone. Only amateurs mess with working systems.

  • @nested9301
    @nested9301 2 года назад

    python is beautiful than javascript but ilove them both xD nice video!

  • @OloNadTrolo
    @OloNadTrolo 3 года назад

    1:35 that's what type annotations and docstrings are for...

  • @Kevinschart
    @Kevinschart Год назад +1

    I have always found the "pythonic" version of code to be non intuitive. I like the traditional if statements.

  • @SecretSanta-hg5yh
    @SecretSanta-hg5yh 3 года назад +1

    Why not use python black directly?

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

    Is sourcery and such extensions as copilot, recommended for a junior developer with 4 months experience?

  • @RobertBrunhage
    @RobertBrunhage 3 года назад

    I don't even use Python but I am a simple man, If you upload I watch 😎

    • @patloeber
      @patloeber  3 года назад

      Haha thank you Robert, I don't use Flutter but I also watch a lot of your videos :D I can learn a lot from your video style!

  • @anelm.5127
    @anelm.5127 3 года назад

    You should definitely do more code refactorings

    • @patloeber
      @patloeber  3 года назад

      thanks for the suggestion :)

  • @dcy3223
    @dcy3223 3 года назад

    thank your tips, your code font is also beautiful, i like it, Can you tell me which one font?

  • @SahilVerma-wm6ie
    @SahilVerma-wm6ie 3 года назад

    For #6 since you aren't computing anything inside the if statements, you can also just do
    return weather.is_raining or is_stylish
    Does this make sense to others?

  • @iamdanfleser
    @iamdanfleser 3 года назад

    what theme do you use for the ide?

  • @PritishMishra
    @PritishMishra 3 года назад

    Which VS Code Theme you are using Sir?

  • @pythonicworld5026
    @pythonicworld5026 3 года назад

    Quick Python Refactoring Tips (30 Second videos): ruclips.net/video/D4xLPfetZRY/видео.html

  • @satishshah9507
    @satishshah9507 3 года назад

    Sir, Please bring a series of #pywebio with best web app examples.

  • @mikapeltokorpi7671
    @mikapeltokorpi7671 3 года назад +1

    #5 How about:
    x = 1
    if !(condition):
    x = 2
    #7: last else is unnecessary.

    • @patloeber
      @patloeber  3 года назад

      yep that's another good option 👍

    • @toddkes5890
      @toddkes5890 3 года назад

      For me the first variable would be my 'default' condition, then the subsidiary conditions would be tested against. I.e. you are taking in a multi-line file and depending on the data you output it into different files. The default setting for a line of data would be "unknown record type", then I see if the record fits into a condition. If the record never fits any of the conditions, that record gets tossed into an "unknown format" file for the user to figure out, and if needed add more conditions to the program

  • @AntonioSanchez-bi3nu
    @AntonioSanchez-bi3nu 3 года назад

    Nice.

  • @ThePirateHistory
    @ThePirateHistory 3 года назад +2

    more pls.

    • @patloeber
      @patloeber  3 года назад

      I try to come up with some more :)

  • @maahad767
    @maahad767 3 года назад

    I follow every tips except the inline condition due to readability and any(list) because I forget 😂

  • @dbldekr
    @dbldekr 3 года назад

    Nah, just right click on random code and click your IDE's "refactor" button and trust that your code is better. I'm a profession programmer.

  • @lmaootakedh
    @lmaootakedh 2 года назад

    Huh, I refactore my code alike.

  • @SamrudhSwaminathan
    @SamrudhSwaminathan 3 года назад

    When You're First So You Don't Know Wut To Comment 🤔...

    • @patloeber
      @patloeber  3 года назад +1

      haha :D

    • @SamrudhSwaminathan
      @SamrudhSwaminathan 3 года назад +1

      @@patloeber Omg Thx Soo Much For REPLYING!! I'm a Big Fan Of U And Uve REALLY Helped Me With PyTorch!!
      TYSM

    • @patloeber
      @patloeber  3 года назад

      @@SamrudhSwaminathan Thank you! Glad you like it :)

  • @kongoulan
    @kongoulan Месяц назад

    First don't use classes in python and all is fixed.

  • @vasiliigulevich9202
    @vasiliigulevich9202 3 года назад +1

    These are all style fixes that do not affect readability or function. Are you changing working code just to satisfy your subjective sense of beauty? Please don't work for me.

    • @lepidoptera9337
      @lepidoptera9337 3 года назад

      Yep. You can tell that it's amateur hour. Worse, it's amateurs with OCD.

  • @Aldraz
    @Aldraz 2 года назад

    One line if statements should be forbidden.. it is so unreadable, ugly.. nah no thanks man.

  • @Hecticam
    @Hecticam 3 года назад +1

    why u gotta sound like that bro