Python Sucks And I LOVE It | Prime Reacts

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

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

  • @riemervdzee
    @riemervdzee Год назад +1978

    Python is the second best language for every software problem

    • @batatanna
      @batatanna Год назад +65

      Oh no you didn't

    • @drdesten
      @drdesten Год назад +220

      that actually sums it up pretty well

    • @SimGunther
      @SimGunther Год назад +16

      What was the best, C?

    • @lazyman2451
      @lazyman2451 Год назад +20

      You know what's sucks, when programming an ai that uses too much resource overheat the gpu 😂.

    • @louisf2506
      @louisf2506 Год назад +271

      @@SimGuntherwhat they meant was, the best language depends on the project, but Python is the second best choice for every project

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

    LOL. Just stumbled on this.
    I wrote a C extension for Python that eventually became the CSV module in Python.
    I did it because i was working on a fixed price project dealing with 100's of megabytes of CSV files exported from SQL Server via Excel (don't ask... Finance people are strange). Each iteration of my code during development took 45 minutes using a pure Python parser I wrote to strictly implement Excel semantics. It was literally costing me money that Python was so slow.
    I figured I could develop the parser in C and finish the project in less time than just continuing in pure Python. Turned out I was right.
    I submitted the pretty raw code to the Python project and over a couple of months, with the help of two other people, made it a lot nicer to use.

    • @Margen67
      @Margen67 8 месяцев назад +12

      Piplup needs HUGS

    • @jamesbedwell4715
      @jamesbedwell4715 5 месяцев назад +16

      You literally wrote the module that I used to write my first commercial project 😍 thanks man xx

    • @davejohncole
      @davejohncole 5 месяцев назад

      ​@@jamesbedwell4715that is awesome.
      I figured back in the day that if I was struggling with reliability parsing massive amounts of CSV, then some time soon, someone else would be.

    • @resresres1
      @resresres1 4 месяца назад +7

      Just curious if Pandas uses your CSV extension in the read_csv() function? i've used it to read csv's in many programs i've written. Lately though I've moved away from using CSV's at all though unless the person wants data stored in a csv file. Have switched to using sqlite3 a lot.

    • @davejohncole
      @davejohncole 4 месяца назад +5

      ​@@resresres1I doubt it. Pandas probably loads data into arrays of native values. The CSV parser creates Python objects.

  • @macaroni_italic
    @macaroni_italic Год назад +552

    I used to be vehemently against Python for superficial reasons until I actually learned it. Sure, it's overly opinionated about shit that doesn't matter (indentation) and it has a few truly gross quirks (loop variables are available out the loop itself, rather than being scoped to it). But it's just a really fantastic scripting language. If you're trying to write something quick and dirty to solve an immediate problem, it's really hard to go wrong with Python. It reads and writes like a perfect, formalized version of pseudocode. It's got great built-in libraries, and its popularity means that it has shit-tons of amazing third-party libraries covering pretty much any use case you can imagine. And honestly, gripes about performance are completely overblown. Nobody is trying to write bare-metal systems code in Python, and if they are, they've simply chosen the wrong tool. That doesn't make Python a bad language.

    • @billy818
      @billy818 Год назад +87

      But also all the stuff that needs to be quick has something like a C backend it interops with anyway.
      take:
      Pandas
      Tensorflow
      Pytorch
      Numpy
      etc
      they are all interoping with something faster behind the scenes to do thing like malloc contiguous memory ect
      python is just the application logic and they are fast enough 99.9% of the time.
      Pure python is slow, sure, but if you are using python is probs because of a libary it has.

    • @thekwoka4707
      @thekwoka4707 Год назад +5

      Past that though, it is pretty awful.
      And apps made with it get REALLY stupid to work with.
      JavaScript does better performance, easy scripting, and less foot guns. A few less anyway.

    • @lunafoxfire
      @lunafoxfire Год назад +16

      I hate python's variable declaration and scoping. It's way too easy to write unreadable spaghetti.

    • @danielvalle8875
      @danielvalle8875 Год назад +33

      > It reads and writes like a perfect, formalized version of pseudocode
      Pretty good description of Python

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

      @@lunafoxfire And get side effects

  • @CottidaeSEA
    @CottidaeSEA Год назад +255

    The thing I like about Python is that it's really good for getting basic things out of the way quickly. As long as you have a library that does the thing you need to do, you'll probably have good performance, because that'll be written in a more performant language.

    • @JohnSmith-ox3gy
      @JohnSmith-ox3gy Год назад +27

      It's as simple as running hack.exe and saying "I'm in."

    • @melonenlord2723
      @melonenlord2723 Год назад +6

      You hope that it's written effective and not uses another 20 packages just to do simple stuff that can be written in a few lines of fast code xD

    • @CottidaeSEA
      @CottidaeSEA Год назад +3

      ​@@melonenlord2723 Pretty much, yes. That's one of the reasons why I check the dependencies of anything that I am planning to use long-term.
      Edit: Originally wrote it differently, but the phrasing was a very ugly double negative.

    • @HitBoxMaster
      @HitBoxMaster 11 месяцев назад

      Correct. Let the C/C++ autists struggle. I wanna have fun programming 😂

    • @kayakMike1000
      @kayakMike1000 8 месяцев назад +1

      Mostly... Those libraries suck, mostly. You would be surprised what can be done by the standard library.

  • @timmy7201
    @timmy7201 Год назад +256

    As an embedded dev, who usually develops for embedded Linux systems:
    - I'm all in on C/C++, whenever there is time to build something.
    - I'm all in on Python3, if management wants it by yesterday!
    I rather spend my evenings working on my own coding projects, versus working unpaid overtime in C/C++ due to management being incapable of planning ahead!

    • @maxinealexander9709
      @maxinealexander9709 8 месяцев назад +1

      Same here, also an embedded dev, agree 100% with this!

    • @poogle9368
      @poogle9368 7 месяцев назад +1

      I'm really enjoying my embedded classes in engineering at uni... what sort of companies hire doing your sort of work? What kind of boards are you mostly working with?

    • @timmy7201
      @timmy7201 7 месяцев назад

      @@poogle9368 I've done a ton of different projects over the years.
      I started out with embedded systems, for museum and attraction park equipment. After that I went to work at a university for some years, helping post-docs with automating their scientific research. I then went on working for a small engineering firm, which develops medical and aerospace equipment for larger corporations and startups.
      All above jobs where very interesting, but came with tons of red tape and bureaucracy. So I changed job once more, and now work in a medium sized company that develops access and control systems.
      Most boards we use are custom made, usually made with Altium or KiCad. They contain a broad range of controllers (imx8, RPI-CM4, ESP32, STM's, etc ...)

    • @timmy7201
      @timmy7201 7 месяцев назад

      ​@@poogle9368 Most boards we use, are custom made. But they contain a plethora of chips, eg imx8, RPI-CM4, STM32, ESP32, etc ...
      For what companies, there are some larger firms and a plethora of smaller startups.
      The smaller startups are often fast-phased and not for everyone. I however prefer them, as there isn't as much bureaucratic overhead.
      The larger corporations are extremely well structured, however everything moves at a snails phase which frustrates me massively...

    • @timmy7201
      @timmy7201 7 месяцев назад +1

      @@poogle9368 Most boards we use, are custom made. But they contain a plethora of chips, eg imx8, RPI-CM4, STM32, ESP32, etc ...
      The company recommended for you, usually depends on age, interests and personality.
      The larger firms are extremely well structured, usually respect the 9-5 workhours, with better pay, etc ... Those larger firms are however very bureaucratic, which makes everything progress at a snails phase. I can't stand it, so I avoid these firms.
      The smaller startups are usually very chaotic, with less respect for the 9-5 workhours, and less pay... The projects are however fast-phased, which means you get a new technical challange about every other month.
      The only thing I always recommend, is to work for a company that direclty profits of your work. I mean with this, make sure the product you develop is meant to be sold! Avoid companies that hire you for internal service or development work, they usually deem your function as an unavoidlable overhead.

  • @frustratedalien666
    @frustratedalien666 Год назад +87

    I relate with this guy. I had a few years of experience writing assembly, C, and C++ code when I first came across Google's Python training videos. I could code but I didn't like coding. 2 days with Python totally changed that. I remember writing a script in 30 minutes that scraped transit timetables from a website and helped me finish a data analysis project that would have typically taken me a long time to write. I've loved Python ever since and though I spent years writing Java, I finally managed to switch to Python professionally and love it. New releases of Java, especially with Streams have made Java a lot easier to like, but I still prefer to use Python for nearly all of my personal projects. The new proposal to remove the GIL from Python should make it run a lot faster soon

    • @burarum1
      @burarum1 Год назад +4

      Yes there will be a official no-GIL version of python but just like all the other attempts in history it will make single threaded performance worse.

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

      @@burarum1 we could have the two and like use one rather than the other as soon as we multi thread

    • @-ciii-
      @-ciii- Год назад +1

      relatable

  • @AdamHoelscher
    @AdamHoelscher Год назад +34

    I very much enjoy your videos on the whole. Your mix of bawdy humor and blunt CS commentary has me constantly swinging between learning something fantastically valuable and laughing away the annoyances of my career.
    This one especially spoke to me. I work as a Data Scientist. I will out-Excel 99% of the world, I learned VBA (shudder) as my first language, I love R for my EDA and I will script any random thing that I expect to run twice (once when I think I know what's going on, again when I realize I f'ed up and it's more complex than I thought) in Python. My employer is constantly pushing for more speed and that has me deep in Go and and exploring Rust. These are all fantastic tools, *for purpose*. I'll never write a Go program to graph correlation from a sample data set, and I'll never write R to run a publicly exposed web server. People who shit on a certain tool don't understand the power of context and the fact that you, the Crustious Crustacean RUclipsr I know of, will flat out say "Python can be a quick W; when you just need to get something done, get it done" makes me smile. Sometimes, it's just the right tool.

  • @cusematt23
    @cusematt23 Год назад +18

    I am just starting my coding journey. Your videos have this incredible way at jabbing at the little idiosyncratic nuisances that even a beginner like myself encounters. Really entertaining channel man I have laughed out loud several times. Quite informative too honestly, since sometimes making fun of a certain issue makes it more relatable to our own experiences, which makes it easier for us to understand why that certain issue exists in the first place. Holy run on sentence.

  • @The1RandomFool
    @The1RandomFool Год назад +63

    The main reason I learned Python was because of my hobby in higher mathematics. The open source software SageMath is wonderful and is built on slightly modified Python.

    • @thomasvandervliet9387
      @thomasvandervliet9387 Год назад +3

      If you hobby is mathematics try Lisp or Clojure

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

      I remember trying Sage like 15 years ago bc I didn’t want to buy Mathematica or matlab. I’m guessing it’s way more useable now

  • @khhnator
    @khhnator Год назад +356

    the problem is that every small program eventually will become a massive enterprise mess

    • @virtuosisimo
      @virtuosisimo Год назад +44

      Yes, I usually like starting my messes in bash

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

      @@Derian_De_Greyyeah, and at the end there is no difference AT ALL in time spent, in comparison with just all the way mastering C from the start, for example.

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

      Then go use C, its been the same forever and is the grandfather of all.

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

      @@Derian_De_Grey idk i guess it exists as spotify and instagram are running django

    • @austenmoore7326
      @austenmoore7326 Год назад +14

      No every enterprise program started small but most small problems stay that way. You just never have to think about them again if their pure one offs lol

  • @xesf
    @xesf Год назад +27

    I end-up in python for obvious ml reasons and I agree with the article. It is a joy to script in python exactly because you can get stuffs up and running pretty fast. For me is like executing pseudo-code!!!

    • @Alfred-Neuman
      @Alfred-Neuman 6 месяцев назад

      When I was young we had something called Basic, it was similar to python in many ways. For example it was easier to learn, simpler to write and ran slower than C or ASM. And just like today, the "real" programmers that were seeing you using this automatically had to look at you with disgust... lol
      Plus ça change, plus c'est pareil!

  • @Taverius
    @Taverius Год назад +152

    I can believe the LISP thing, once you've done enough CL/Scheme/Clojure the parenthesis madness disappears like the code of the matrix and you just see the tree of code, it's like learning Vim motions. Takes a *while* to get there tho ngl 🤣

    • @macaroni_italic
      @macaroni_italic Год назад +9

      Yeah, Lisp is actually a very productive language. With a proper programming environment, the parentheses are a non-issue. You can write extremely elegant solutions to problems.

    • @MoolsDogTwoOfficial
      @MoolsDogTwoOfficial Год назад +16

      @@macaroni_italic (are you(sure(about that)))

    • @NoidoDev
      @NoidoDev Год назад +4

      Lisp is so good that it is likely the reason for it's "failure". Guys can write programs on their own, don't care about documentation and making other people understand their code. Also, they don't want to teach anyone, since it's their secret sauce, or because they could write more programs in the time they waste on teaching people about how it works writing documentation.

    • @aoeu256
      @aoeu256 6 месяцев назад

      @@macaroni_italic Man I want me some LISP jobs, I like you can resume after errors. LISP is less standardized than Python in its libraries though. You can use macros in Python by using sexp Python like Hy btw.

    • @aoeu256
      @aoeu256 6 месяцев назад

      @@NoidoDev Dude with Lisp/Smalltalk/Python you can write introspective tools to help you trace what programs are doing thanks to their dynamicity. You can use static type inference as well. Like in LISP you can run code in your own custom eval that produces a trace history for all the variables of a function call and then customize Emacs to show you it (hint: replace apply, let with your own version of apply/let that keeps a history). Another thing I saw people do in Python is to get a __getattr__ proxy objects that log what methods are used on them and find all callables in sys.modules (all your symbols) and pass in your proxy objects to generate a "dynamic" type, and this kind of technique can be used for Smalltalk and LISP as well.

  • @vikramkrishnan6414
    @vikramkrishnan6414 Год назад +33

    Lisp actually takes very little time to develop because code = data. So you design your data structs and algos follow naturally. I wrote some Clojure code and it was a pleasure to write in

    • @laughingvampire7555
      @laughingvampire7555 Год назад +4

      and if you use common lisp, your dynamic code will run faster than any python code, and even faster than clojure. all you have to do is use SBCL and CLOS, for the javascript part you use parenscript a compiler of a subset of cl to js

    • @balenol1209
      @balenol1209 Год назад +2

      I still have no idea how lisp programmer can be confident when using a function in lisp without knowing the types of the input.

    • @vikramkrishnan6414
      @vikramkrishnan6414 Год назад +2

      @@balenol1209 LISP is the OG REPL-icious language. Just turn on the REPL and call the function

    • @balenol1209
      @balenol1209 Год назад +5

      @@vikramkrishnan6414 that's not a good argument. Using REPL is cool to test a function, but it wouldn't catch the requirement of an input's type holistically.

    • @BosonCollider
      @BosonCollider 7 месяцев назад

      @@balenol1209 Typed scheme exists, you can implement a type checker using macros. But mostly it is indeed the OG dynamically typed language. Some dialects have first class contracts as the idiomatic way to enforce constraints, including type constraints

  • @Xemptuous
    @Xemptuous Год назад +29

    Python is what I use at work, and it's so easy to do simple things like getting data from APIs and doing ETLs and other data manipulation. It's like bash in that it's super easy to automate and finish something quickly that works "fast enough" for most things that most people need.

    • @computerfan1079
      @computerfan1079 Год назад +3

      Python and data processing are a match made in heaven

    • @thorbergson
      @thorbergson Год назад +7

      And with readability that bash scripts can only dream of. Generally, I find that you have to be actively malign to conceal your intent in Python. It can be ugly, inefficient, babbling, but rarely do I stare at a Python function thinking "what the f* is this even doing?" which happens a lot in some other languages

    • @darkwoodmovies
      @darkwoodmovies 7 месяцев назад

      I'd like to know how many hours of oncall and lost engineer productivity could be traced back directly to a lack of typing and the shitty patterns in Python. I see it all the time in frontend work, the JS code always has random bugs that we have to fix, but the correctly-typed TS code almost never has issues unless something in the backend changed.

    • @aoeu256
      @aoeu256 6 месяцев назад

      @@thorbergson You can also generate type hints by using static or dynamic type inference in Python.

  • @billy818
    @billy818 Год назад +71

    On the point about type script being "enterprise" and allowing you to build these huges messes
    python has inbuilt type hints with generics and union types now

    • @calliioa
      @calliioa Год назад +29

      as someone who uses mypy and type annotations like it's the bible, not really
      type annotations is the greatest python feature in recent memory, intellisense, code docs and reading/writing code is so much more ergonomic with it
      however, it's just that - annotations
      you still need the external mypy tool to type check your code and python will still be python, lazily typed and runtime type error prone, it really just helps to double check your code rather than to be a better language
      plus python already is kinda enterprise already tbh

    • @fueledbycoffee583
      @fueledbycoffee583 Год назад +16

      @@calliioa we run a python backend for our platform with flask and we use python type annotations like if it was typescript. I love it and makes everything more ergonomic to work with

    • @smallfox8623
      @smallfox8623 Год назад +7

      Python's built in type hints are epically shit. They are orders of magnitude worse than TypeScript types.

    • @cheaterman49
      @cheaterman49 Год назад +15

      @@smallfox8623 Hard disagree, particularly considering recent progress, and it's only getting better.

    • @KayOScode
      @KayOScode Год назад +2

      Making it more of a mess. Why not

  • @leetaeryeo5269
    @leetaeryeo5269 Год назад +41

    This article really captured my thoughts on Python well. It's not the most performant language out there in terms of raw execution speed (you can improve it with Cython or PyPi, but still, it's never gonna be C or Go or Rust), but the speed and ease at which you're able to just solve a problem with a usually reasonable level of performance just feels good. I've started using it a lot for smaller automation tasks and alerts for technologies that don't have good tools for alerting. And Flask legit is just my favorite micro web framework (despite all the problems with microservice architectures). The productivity is just so nice, so long as you keep in mind that you need to use the right tool for the right problem (a Netflix-scale web API probably needs something more performant).

    • @whu.9163
      @whu.9163 Год назад +6

      Python devs have FastAPI. Why would you use Flask instead of it? I'm not a pythonista myself to prove next statement but this microframework looks like a game changer for python in web)

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

      @@whu.9163 what are the major differences?

    • @FrederikSchumacher
      @FrederikSchumacher Год назад +6

      Using Flask is like saying a roof ripped away by a tornado a minor inconvenience. It's not completely wrong, but massively understates the complexity of the situation, and depends on the focus of the observer.
      FastAPI very easily allows mixing async and sync handlers. Integration with Pydantic is non-frictional. Writing something small using decorated endpoint handlers is as easy as creating more class-based endpoint handlers (unlike Flask). The dependency injection works and is welcome for anything slightly more complex than the trivial tutorial examples in Flask. There are some annoyances, mainly the default error handling mechanism is absolute ass, and just about requires complete replacement for even the most trivial customization, just like adding CORS support (either the default is okay for you, or you have to configure _everything_). Also the main documentation is largely okay, however severely lacks a reference section.
      Although it must be mentioned, a great deal of FastAPI features are actually just Starlette features, the framework FastAPI is based on. And often there's better information in the Starlette docs than there is in the FastAPI docs, something where the FastAPI developers could make more effort to at least _link to_.

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

      So you're saying you would use FastAPI Any day over Flask ?@@FrederikSchumacher

    • @auroraRealms
      @auroraRealms 6 месяцев назад

      @@conan_der_barbar FastAPI is asyncronis, by just adding the "async" keyword if front of functions. FastAPI also provides a complete "docs" page that automaticly writes all the API documentation. Also, FastAPI is the new rookie kid on the block. So the only real reasons to use Flask are, that it is grandfathered in, or if you want to make a Rapid Development Website for a limited number of users inside a Subnet.

  • @itmecube
    @itmecube Год назад +11

    "Lisp is used to tell other people you do Lisp." - Rust guy who does Rust

  • @carlwilde635
    @carlwilde635 Год назад +15

    Pythonista - An anagram of “A Hypnotist”

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

      dios mio you are right

  • @hotfishdev
    @hotfishdev 8 месяцев назад +9

    The best program is the one that does its job. A program cannot do its job unless it is written. If Python lets you actually write the program where another language would have been a blocker, it was the best language for the job. If you need to consider changing the implementation language later, you’ve won.

  • @haxwithaxe
    @haxwithaxe Год назад +28

    In the past 8 years I don't think I've come across situations where python wasn't performant enough with room to spare even when I was doing things that needed to be as fast as possible (DNS server oddly enough). More than 8 years ago I did a bunch of image processing that python couldn't do in a timely manner. That was doing a visual diff between documents thousands of pages long.

    • @crsv7armhl
      @crsv7armhl 17 дней назад

      I realize you posted this a year ago, but radio need microsecond resolution, and python is too slow for it, same with embedded stuff.

    • @haxwithaxe
      @haxwithaxe 17 дней назад +1

      @crsv7armhl yeah if you need the absolute pinnacle of performance python isn't the right tool but the vast majority of usecases don't need microsecond precision and embedded python works just fine with similar caveats. In some cases you can also offload high-performance subtasks to other languages like C or rust and just do the high level logic in python. My point was that an awful lot of stuff can easily fit within python's limitations not that it's suitable for everything.

    • @crsv7armhl
      @crsv7armhl 17 дней назад

      @@haxwithaxe I absolutely agree. Most of my code is either only written in python, or initially written in python then written in something else.
      Radio is the one exception where I always start with C/C++ but it is usually running on an MCU with a transceiver anyway. I still use python for an interface with the FW though!

  • @kubre
    @kubre Год назад +24

    Just like [x for x in list] you can use parenthesis instead of square brackets like (x for x in list) to use generator comprehension instead of list comprehension, which is lazily generated

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

      If you pass it as the only argument to a function, you don't even need the parenthesis. foo(x for x in lst)

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

      @@mattmess1221 this is also true but usually looks kinda ugly for more than 1 arguments

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

      You can do this for other types:
      tuple(x for x in some_list)
      [{x:y} for x, y in some_list]

    • @maleldil1
      @maleldil1 8 месяцев назад +1

      @@kubre for more than one argument, then parentheses are mandatory.

  • @hawkingradiation3774
    @hawkingradiation3774 Год назад +25

    how does he get this kind of energy, feels like he is always on crack to get this energy in him, and his video edits are hilarious

    • @miguelarribas9990
      @miguelarribas9990 Год назад +14

      Too much time in front of a screen doing software engineering causes changes in the brain that alter how reality is perceived, akin to consumption of psychodelic drugs or achieving nirvana by self starvation. I am working hard to reach that state of consciousness that he has achieved.

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

      @@miguelarribas9990 yeah me too

    • @GAT0SY
      @GAT0SY 11 месяцев назад

      the ultra [coding] instinct.

  • @gracjanchudziak4755
    @gracjanchudziak4755 Год назад +37

    Fun fact: they can easly make Python much much faster, but they don't want lost all compatibility with tools, librares and frameworks.

    • @oderchannel426
      @oderchannel426 Год назад +3

      I mean they were fine with losing compatibility when making python 3 lol

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

      @@oderchannel426 no, they were shocked by the number of tools written in Python. Check what Guido van Rossum thinking about this.

    • @Acorn_Anomaly
      @Acorn_Anomaly Год назад +17

      ​@@oderchannel426yeah, and look how much of a problem that was. There's shit out there that still won't get off 2.7.

    • @brunorodrigues5718
      @brunorodrigues5718 5 месяцев назад

      ​@@oderchannel426Python 3 was such a huge mistake and mess that CPython coredevs are saying that there will never be a Python 4.

  • @MaryTheTankGirl
    @MaryTheTankGirl Год назад +16

    Apparently C is easier to work with then Java, and also runs faster, so my takeaway is I'll be using C.

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

      It takes forever to get anything done, but the simplicity makes the footguns more obvious (also the low level makes the footguns more like foot dynamite). C++ is particularly guilty of making the footguns non-obvious, and sometimes UB takes millions of iterations to surface, good luck finding them in your test suite :-/

    • @MaryTheTankGirl
      @MaryTheTankGirl Год назад +3

      @@cheaterman49 I think this is true, but C is not C++. I feel C is very clean. There are not a lot of concepts you have to hold in your head. If you know how the memory works it’s very clear. C++ just adds a lot of abstractions that make things less obvious.

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

      Yeah that was also where I stopped taking that graph seriously

    • @isodoubIet
      @isodoubIet Год назад +3

      @@MaryTheTankGirl " C++ just adds a lot of abstractions that make things less obvious."
      Yeah but those abstractions when designed well are incredibly helpful. There's no universe in which mallocing and freeing everything explicitly is better than using vector or unique_ptr. There simply isn't.

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

      @@isodoubIet Absolutely 💯. I didn’t mean to imply that these abstractions are bad. I just think it’s more complex, because there are more features.

  • @vex355u_fan
    @vex355u_fan Год назад +7

    The elephant in the room for Python: package management. It's terrible and there are no good options. Conda takes forever to build environments. Pip may not give a valid environment at all.

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

      this right here is why i shift my attention as a scientist to Julia (I know it is not a general purpose as python especially cause static compilation is not yet a thing) and Rust because their Package managers are superior. Julia built from the begining with both a package manager and environment manager. And the greatness that is cargo in Rust.

    • @VH-in9jj
      @VH-in9jj 6 месяцев назад

      Mamba

  • @laughingvampire7555
    @laughingvampire7555 Год назад +2

    common lisp is faster than python in both runtime execution and productivity. This is why Rich Hickey who was a C++ expert with 15 years of experience chose Lisp over C++
    Hickey was making a software for a customer he first made it in common lisp, took him 6 months then the customer was impressed of how fast that was but had an additional requirement it had to be in C++ and Hickey with having the problem figured out, rewriting it in C++ took him 18 months.

    • @aoeu256
      @aoeu256 6 месяцев назад +1

      Common Lisp is faster to develop for custom solutions that don't require many standard libraries since you can rerun code after you get an error, however, since its a LISP there is no standard library ecosystem. Every LISPER creates their own eDSL to solve their own problems, and other people may not understand their code. Also why not use custom compilers to convert code from LISP to C++, and write a LISP eval function in C++ to handle certain difficult cases.

  • @k98killer
    @k98killer Год назад +53

    I have been using Python to make reference implementations of stuff I found in math and computer science papers for a while now. Great language for doing that. For example, I recently created a genetic algorithm library; I started in Python, then reimplemented in Go; Go was more performant by a wide margin even before I refactored to use memory pools (which resulted in a 99.94% reduction in benchmark times for simple use cases).

    • @tytywuu
      @tytywuu Год назад +3

      That's a very nice roadmap - you must have learned tons from it!

    • @k98killer
      @k98killer Год назад +4

      @@tytywuu I have, yes. Very fun way to get back into the groove of things after being sick and useless for 3 weeks. Prior to the illness, I was implementing the Practical Isometric Embedding protocol, but I've put it on the back burner for now. A couple months ago, I implemented a scripting language based on Bitcoin script for use as embedded ACL in distributed systems; last year, I made a bunch of advanced cryptography proofs-of-concept (e.g. taproot and ed25519 signature adapters); the year before that, I implemented MuSig. Python is my go-to language for figuring stuff out because all the building blocks for anything I want to do are available.

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

      ​@@k98killerwow how long you been programming? What was your first language? What all projects you did at the beginning?

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

      @@mallukittens177 I started as a kid writing batch/command scripts in Windows XP; within a few years, I had learned c/old c++ on Linux, a Windows scripting language based on Basic called AutoIt, and bash scripting. In highschool, I learned JavaScript, ActionScript+Flash, HTML+CSS, and PHP.
      From the start, my interests were largely in networked/telecom programs. One early project was using the built-in CLI network tools on Windows to make a simple chat program. One of my first C programs was a UDP chat program on Linux. I basically try to make chat apps in every language I learn using whichever methods/strategies i think are worth exploring, e.g. I explored multicast UDP a few months ago.

  • @chndrl5649
    @chndrl5649 Год назад +49

    As a data scientist, I can tell you that’s why I love Polars as a baby of mama RUST and Python. It so fast to process and analyze data, both development ease/time and performance

    • @Fiercesoulking
      @Fiercesoulking Год назад +4

      You can use the compile option unter Linux with Pytorch but it won't be as fast as C++ at least not until everything is compiled., I'm just a guy playing around but I just recreated my Python NN with all its function in Pytroch C++ Frontend, It went from ca 40-60 minutes down to 4 minutes and I'm still in Debug . When you run this in an professional environment this makes huge difference in money.

    • @allah9896
      @allah9896 Год назад +3

      In what aspects is polars faster? It’s just parallelizing the processes automatically under the hood from what i’ve seen. Is there something else that makes it more efficient? I tested polars code and pandas split up in a multiprocessing pool and the time was the same. just curious as i’m a data science intern atm.

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

      @@Fiercesoulking Yeah the big deep learning frameworks are all catching up with performance. It does make huge differences~

    • @chndrl5649
      @chndrl5649 Год назад +2

      @@allah9896 I mean query optimization is pretty great, and also the syntax just make the coding part so much more efficient and easy to follow

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

      @@allah9896 How big is your dataset? If it is 10,000 items, you probably won't notice any difference between them. But if it is 60,000,000, like a dataset I'm working on at the moment, Polars is very fast whereas Pandas just falls over.

  • @0xCAFEF00D
    @0xCAFEF00D Год назад +5

    1:50
    CPython (what you get if you apt-get python3) does not have a JIT. pypy is a jitted interpreter of python. It's alright. Don't recall if they support the entire language or what was going on but I've used it and it works alright. It's no V8 though.

  • @RogerValor
    @RogerValor Год назад +31

    I find python actually nice for large projects, if the project is mainly dealing with database work or handling lots of exotic ever changing business requests between multiple apis.
    So big horizontal projects.
    I saw once a java api read our output back into their system, where they were the source of truth, simply because they found our data more reliable than their own, and because implementing the validation in their project took way longer.
    i think it is because of dictionaries and lists, having untyped dict class as first class citizen also makes it really easy to deal with json, while actually all the typing tools like TypedDict, dataclass, namedtuple and whatnot help you to formalize the actual data structures in various ways.
    in companies, where you are helplessly bound to other apis written by multiple teams, the python team is like a beacon of hope, while also usually being super humble since they know python is much easier and slower, and are used to being belittled.

  • @Ceelbc
    @Ceelbc Год назад +5

    You can add type hints in python. Your IDE will give you warnings when you don't follow those.

  • @3_14pie
    @3_14pie 11 месяцев назад +1

    I don't dislike python, dislike how everyone seems to go directly for python just because a random guy on the internet said it is "easy", "can do anything" and "you can get a job in 2 months"

  • @4idenn
    @4idenn Год назад +6

    As a Pythonista myself, I love this article

  • @scorpo999
    @scorpo999 Год назад +27

    it is even harder to distribute python than TS.
    A lot of python modules rely on OS level packages, you can install something with pip and it will still not work.

    • @edwardcullen1739
      @edwardcullen1739 Год назад +2

      This is as true as it is false. There's many reasons for this, least of which is that libraries are badly written or only supported on one platform.

    • @scorpo999
      @scorpo999 Год назад +2

      @@edwardcullen1739 from my personal bias exp js/ts tend to be more plat agnostic as authors tend to not step outside of node/ js/wasm sandbox.
      with wasix i think this will skew it even more in the future as some of the c libs could be recompiled.

    • @eUnkn0wn
      @eUnkn0wn Год назад +2

      That's why you use venvs and setuptools or Poetry.

    • @isodoubIet
      @isodoubIet Год назад +5

      @@eUnkn0wn The fact that you need something like venvs to make sense of the dependency hell is as much an indictment of python as anything.

    • @stxnw
      @stxnw Год назад +2

      @@isodoubIetYou use node_modules..

  • @douglascerqueira9537
    @douglascerqueira9537 Год назад +3

    in the icpc (international collegiate programming contest), the python is in fact more fast to write, if you has the best solution in python and other language, python will be more easy to easy to write, all those built in methods helps a lot

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

      C++ is king for competetive programming

  • @normalhuman6260
    @normalhuman6260 6 месяцев назад +1

    The way I work is I write PoCs in python. It gets me to what the actual logic is going to be for a project and then I just write the production code in C++. Saves incredible amounts of time in debugging experimental PoC code.

  • @miguelacuna7148
    @miguelacuna7148 Год назад +5

    Love your content, you give me some Dr. Disrespect vibes but for engineers.

  • @bennyp_thechemist
    @bennyp_thechemist 2 месяца назад

    I'm a computational chemist. When I want to do a huge set of calculations or build a simulation I'll use something like rust or C++ but most of my coding involves generating input files and pulling info from some esoteric data files and plotting it and python serves me so well in just a few lines. It's not fast, but it's faster than me, and I can get a plot done 15 min before a meeting.

  • @thundercat9902
    @thundercat9902 Год назад +3

    Why the hell he read Julia this way(1:25)

  • @TheLinuxGallery-qz2vs
    @TheLinuxGallery-qz2vs 6 месяцев назад +1

    I like python for short little stand-alone scripts, and rough drafts.
    It's a great language for dashing something together, to address a lot of the questions and uncertainty and preferences you want to handle -- so you don't have to compile every tweak and change, one at a time, into the main project's C++ version.
    The more time you spend in an interpreted language, the less time you spend writing and compiling a C-lang.

  • @ANONAAAAAAAAA
    @ANONAAAAAAAAA Год назад +71

    What I can't understand is the reason why these "performance conscious" developers start worrying about performance even before measuring the performance of the program and identify the bottlenecks.
    For many cases, especially when developing backend systems, bottlenecks tend to live in IO or data storage layer so using "fast" language like Rust, C++ doesn't help much to improve the performances of the system anyway.

    • @ayaderg
      @ayaderg Год назад +43

      right, like these people are making a discord bot, the bottleneck is discord's API, which takes about a second per request regardless of any other factors, so your best bet is to send off as many requests as possible at the start of your command and then do all your calculations while discord is slowly doing its thing, and that's about as performant as it can get no matter your language of choice

    • @avarise5607
      @avarise5607 Год назад +7

      Premature optimization is a problem, but there is validity to speeding up even when bottlenecked by IO. And it is simply to reduce resource usage. Not saying this is major part or important part in early development, but it should not be ignored entirely

    • @marcs9451
      @marcs9451 Год назад +9

      having IO or network bottlenecks is not a valid excuse in most cases. you shouldn't prematurely optimize but "pessimizing" your code isn't good either.

    • @ea_naseer
      @ea_naseer Год назад +2

      ​@@marcs9451... in most cases this falls off that cliff.

    • @cheaterman49
      @cheaterman49 Год назад +6

      @@marcs9451 Profile then optimize. If your code happens to be a bottleneck, first find where/why, then fix it. Prematurely writing everything in the fastest possible way is a recipe for disaster - and that applies to Rust too: as Prime already said, your first implementation of pretty much anything in Rust should be very ugly, very slow, making copies everywhere etc - and if that's fast enough to ship, then no need to waste expensive engineer hours optimizing it further. Python is just taking this approach to an extreme where machine time is considered largely irrelevant in cost compared to human time, and that seems to be true for most companies with most (medium sized) user-bases. It only makes sense to consider machine time when your hosting is within an order of magnitude of an engineer's salary ; if you're paying a $5 VPS each time you do a new client project because there's gonna be less than 1k users, meanwhile the engineer responsible for optimizing said backend costs $5000/mo to the company, the Python approach is the obvious correct one.

  • @raffimolero64
    @raffimolero64 Год назад +2

    "Python is Slow"
    > Discord bot
    tbh the difference in speed between python and rust, is not significant for applications that do a lot of async calls like just waiting for user input and stuff. unless of course your bot is used in a lot of servers or if it does heavy computation or something.
    the author probably knows this anyway :P

  • @fantasdeck
    @fantasdeck Год назад +6

    Python has type hints and mypyc enforces them to compile Python to C with them, alone. The problem is that Python devs routinely don't type-hint their code.

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

      i do love type hinting of python

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

      Well you shouldn't type-hint Python code, at least not in a way that mypyc could valid it. Static typing comes with the drawback of significantly longer development times (usually 3x). Type hints in Python should be reserved for annonating your external API calls in Flask, etc. Not running a type checker.

    • @aoeu256
      @aoeu256 6 месяцев назад

      You can have have decorators, and static type inference that treats a Python like its a Rust or Julia program although won't let you Python's dynamic features like changing the class of an object at runtime.

  • @WaddleQwacker
    @WaddleQwacker 2 месяца назад +2

    i learned python because it's the scripting language of so many softwares i need to make plugins for.

  • @Realrebitsch
    @Realrebitsch Год назад +8

    I am a python developer. It was the first language i have learnt and i just kept getting jobs. It is pretty good for externally bottlenecked, server gluecode projects, but you can shot yourself in the foot with it quite easily. while "anyone can write python", and be super productive, you still want to hire developers who know what they are doing, and give them enough time write it properly, if your project is larger than a few thousand lines. a comprehensive automated test suite is essential. that way it IS faster. but there is a prisoners dilemma type problem with python: you can churn out code that seems to work way faster than it would take to write it in a maintainable way. But since the pitch to the suits was that it would get done fast, it is against your personal interest to do a proper job, because "delivering results" is advantageous to your career. The fact that it will end up taking much longer this way will not lead back to you, because it will just cause the other devs work slower, and incrementally grind the whole project across the board.

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

    I am building my no code tool MVP in TypeScript. Later I’ll build the complete thing in Go. And at the end probably in Rust. Seems like a natural evolution. And what I’ve build so far works great!

  • @jffrysith4365
    @jffrysith4365 8 месяцев назад +7

    this points out the point I always make.
    Python can easily make a reasonably good calculator. If you want to know 50 * 50 you just type 50 * 50.
    In Java you would need to do:
    public class program {
    public static void main(string[] args) {
    System.out.printf("%d", 50 * 50);
    }
    }
    which is significantly longer and easier to mess up. This obv has it's values, but sometimes the performance doesn't matter and you may as well just use python.

    • @arkie87
      @arkie87 6 месяцев назад

      if you know ahead of time that performance is going to matter, there are ways to write python to be fast e.g. numpy, pypy, numba, or cython.

    • @lenkite
      @lenkite 6 месяцев назад

      You don't need the public static and the string[] args bit from Java 21. It has been streamlined considerably.

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

    Python is always a hassle in production! New version of the interpreter that gets install by your OS and your code may break.
    Update of modules and your code may break.
    The mortal sin started with breaking compatibility with 2.7 (idiots).
    Libraries that the module use (especially anything OpenSSL) and your code breaks. *SSL libraries never a dull time (in any language)
    You want a statically compiled binary on production that you know your OS or Docker can change and your code will still work. Python also npm (had that last week at the bank) suddenly doesn’t work because a new version of ADF ARM deployment required a new version of NodeJS. Ugghhhh I hate that! Exact same build function call and yet “version mismatch” wtf?! If the interface doesn’t change your code shouldn’t break! Especially for doing the exact same thing!
    So for just a tool that doesn’t need to run production grade software use what you want. For production grade software I stand with compiled languages with string typing only! And the binary needs to be statically compiled so is independent from system updates.
    But sane people who write Python don’t operate in a mission critical environment (I hope).

  • @flanger001
    @flanger001 Год назад +4

    Laughs and cries in Ruby

  • @hypano
    @hypano 3 месяца назад

    5:40 was so good, you had me already laughing and you just kept going, well done :)

  • @kassios
    @kassios Год назад +5

    You missed a great opportunity to finish with "The name is the pythogen"

  • @cparks1000000
    @cparks1000000 Год назад +2

    Python has typehints and mypy. It has generics and can emulate higher-kinded-types using mypy plugins. You can make a completely statically typed program.

  • @SXsoft99
    @SXsoft99 Год назад +13

    lets be serious, sometimes speed doesn't matter, you dont need c, c++, rust, you need to get the project up faster

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

      Especially when creating a discord bot.

    • @spookycat4620
      @spookycat4620 Год назад +2

      plus why chain yourself to one language be a chad and learn em all

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

    5:17 - 5:36 is by far the best content PrimeDaddy has ever put out there. Ive been dying for 5 minutes and its not my ring tone.

  • @doronvaida
    @doronvaida Год назад +6

    actually python type annotations, static type checkers and a data modeling and validation library like pydantic make developing large scale projects a pleasure.

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

      That is a terrible way to develop large python projects as it slows down your development speed. You should be using microservice based architecture instead.

    • @FlanPoirot
      @FlanPoirot Год назад +2

      mypy is terrible, its type checker is actually kind of faulty, I've caught it allowing me to do stuff that should obviously violate the type system. pydantic requires a rust runtime to know the types, so you have a small performance hit on top of the already slow CPython interpreter/virtual machine.

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

    I think the complete opposite. I've made a Discord bot before. In fact, I wrote the same Discord bot 4 times: the first and second time in JS, the third time in CoffeeScript, the fourth time in TS.
    I can tell you, the third rewrite was by far the worst to work with. There were random bugs occurring due to the lack of static typing, and they took hours upon hours of debugging to find. All these bugs vanished when I rewrote it in Typescript. And it didnt even take more time to make it than when I wrote the coffeescript version. It was just better from the get go.
    Thats why I cannot see myself loving the experience of making an entire product in a dynamically typed programming language. I'll just write code slower because I'm constantly thinking of types I have to now hold in my head instead.
    For me, Rust being fast is a bonus. The *real* benefit is its extremely helpful type system.

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

      Python is a strongly typed language. You can treat it as a statically typed language and have a type checker (called mypy) running while you program. The effect is like Typescript. @Speykious

  • @rando521
    @rando521 Год назад +5

    i just tried that and got more stackoverflow stuff than my actual questions .
    man helped me get stuff done

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

    CPython doesn't have a JIT. There is an implementation of Python (PyPy) that does. But PyPy has compatibility hurdles with Python modules written in C.

  • @gracjanchudziak4755
    @gracjanchudziak4755 Год назад +16

    To be honest Python is the best everywhere if you don't care on performance. Most of webistes don't count prime numbers, it's just pages with some buissnes logic, and Python here can be awesome.

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

      agree, u should try Ruby, man you code lines will be less then it was

    • @CamaradaArdi
      @CamaradaArdi Год назад +2

      I disagree, when the business logic gets too complex types are there to help.
      In my opinion python shines where the complexity of the task is extremely low.
      AttributeError: 'dict' object has no attribute 'creation_date'

    • @ANONAAAAAAAAA
      @ANONAAAAAAAAA Год назад +4

      >when the business logic gets too complex types are there to help.
      Types are just crutch, test codes are the ultimate tool to deal with the complexity imo.

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

      @@CamaradaArdi it's not true - there are types in Python and you can execute them. I was developing complexity website in Python so I don't get this point. Also it's obvious that dict has no method like that so again I don't understand the point, every python junior knows it.

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

      @@ANONAAAAAAAAA very true

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

    REXX (Rstructured EXtended eXecutor) is a very nice language :) It was designed for systems administration. It was also designed to be run interpreted OR compiled. While it's PL/I isnpired syntax may put off someone, it is really an excellent scripting/sysadmin language. BTW I also can run with Perl. If I had to choose between Lua, Python or Perl I'll go Perl any time. And as opposed to NPM, CPAN actually works :D

  • @dontdoit6986
    @dontdoit6986 Год назад +6

    Python lambdas in AWS have lightning fast cold-start speed compared to everything else (except Go lol). If you’re writing basic crud apps using micro-services, Python should be at the top of your considerations. Powerful stuff.

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

      C/C++ should have a very fast cold start time

    • @vncstudio
      @vncstudio 2 месяца назад

      Exactly. I chose Python for AWS due to first class support on AWS and some specific API libraries I needed. I have used Lambda with Step Functions using Map and also Fargate. Great stable performance.

    • @vncstudio
      @vncstudio 2 месяца назад

      @@mihailmojsoski4202 C and Nim have single digit cold starts in AWS Lambda with custom runtime. Very nice.

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

    TypeScript wasn't a mistake. JS on the back-end might be a mistake, but on the front-end - where JS just isn't avoidable - the added stability wheels are a godsend, even if they're phantom wheels.

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

      If only there was an language agnostic execution environment in the browser to allow more languages being used... Oh wait there is, but it just happens to lack crucial features by design. Or those features requiring debilitating workarounds. Ah well, just the typical W3C nonsense.

  • @maevwat
    @maevwat Год назад +4

    I used to do everything in c++ but I haven't touched it in like 3 months after I started doing a lot of small projects in python, I can easily develop anything in a small amount of time

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

      this i got bored one day and and started bangin out like 3 big ass text adventure games want to do a text rpg that incorporates random math for dice roll style combat but i digress my love of python is its clean syntax its simple and clean and effective

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

    getting started on a project or prototyping stuff is way way faster on python, that said, I've worked on a project that had the data gathering and some processing in C++ as it had to be ultra fast, and the bulk of matrix data processing in python... python would've struggled hard on the C++ part, and I would've struggled writing the python part in C++

  • @Ahamshep
    @Ahamshep Год назад +3

    I'm not a very good programmer. I've mainly only used python, but have fiddled around with javascript and C a little. Although the other day I wanted to try something and I was thinking to myself while programming, "Python is like a sketchpad that I can just make doodles in". That ease of use and flexibility really gives even a dumb shit like me the ability to learn and accomplish things.

  • @egzakharovich
    @egzakharovich 7 месяцев назад +1

    The last thing I want to care when writing in Python is "performance". Really. Because I know, it may suck. But the language and pip ecosystem is so good, you don't give a f.
    As we say in Russian: Хуяк, хуяк и в продакшен. Which means like rough and ready, but it works in production. It's the main purpose of Python.
    I don't want to waste time f-ing around types, low-level stuff and compiling. I don't have a time for it, I better spend it elsewhere.
    But if my project suddenly shoots out in a wild and I become a star, there're ways to optimise. Like using async, memory caching or rewriting entirely or heavy lifting only in Rust, Go or C, or other... Like pydantic v2 did.

  • @FrederikSchumacher
    @FrederikSchumacher Год назад +12

    I think it's very clear: people love shitting on forced indentation because they're the guilty ones, the ones with abysmal indentation practices. And Python makes that a syntax error... **giggles**

    • @nithinrajendran3091
      @nithinrajendran3091 8 месяцев назад +1

      Exactly, I consider it a good feature

    • @copperspartan1643
      @copperspartan1643 8 месяцев назад +1

      I just let the editor take care of that and don’t think about it too much in any language. The only exception is in YAML, which sometimes confuses me and the editor.

    • @MungeParty
      @MungeParty 7 месяцев назад +2

      *giggles* should be a syntax error, that was painful to read.

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

    The thing about python is that it is really easy to shoot yourself in the foot by assigning a variable the wrong type or by initializing a variable twice, and with no static checks, the only way to prevent this is to write tests, which I don't like doing

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

      This just happened to me but pycharm easily caught that. Now I'm on astrovim so idk.

    • @aoeu256
      @aoeu256 6 месяцев назад

      If you edit your program with the REPL connected to your running program, can you can just run your tiny pure functions to see if they give the output you want.

  • @krux02
    @krux02 Год назад +13

    I think being able to immediately solve something in a new language is extremely important, much more than performance. That's why I would chose go over python every day. It doesn't hurt that it is also more performant, has better tooling, actual type safety and allows to define data layouts for a low memory footprint.

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

      So, how fast can u make REST project with Golang? or can u make Instagram or Github with Go in 3 days?

    • @prs_wjy
      @prs_wjy Год назад +3

      ​@@merlin7411bruh

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

      @@merlin7411 😂

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

      Even as a card carrying python hater I can't agree with this. Go wants me to code like it's 1970. No thanks.

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

    I'm learning F# and I think there is no need for me to learn python. It is succinct, static typed with the feeling of being dynamic and it is fast. This is my third language after PHP and Js and I love it much more.

  • @ATXAdventure
    @ATXAdventure Год назад +10

    I used to hate python but then I had to get actual work done and it gets stuff done fast.

    • @smallfox8623
      @smallfox8623 Год назад +3

      I used to like Python and then I had to do actual work and it is the worst experience ever.

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

      @@smallfox8623 You either haven't used Java or you love Java.

  • @aabluedragon
    @aabluedragon 8 месяцев назад +2

    12:24 Steve Carell voice moment

  • @cchance
    @cchance Год назад +4

    My issue is the nightmare with dependencies, python versions etc the fact your basically forced to use conda or something to reign things in is insane to me… upgrading python even at minor versions breaks programs sometimes

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

      Really? I've had worse luck with NPM. PIP rarely gives me any issues.

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

      @@redpillsatori3020 oh npm has its issues as well, but node rarely has an issue where going to a newer minor release breaks backwards compatibility that’s def happened with python

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

      You're not supposed to upgrade the minor version (3.x) without being familiar of the changes, because it's likely for things to break
      If you develop with 3.8 then stick with that version, although you could update to 3.8.10 for example

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

      I never use conda, for me it's virtualenv and pip

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

      npm is 999999 times worst than pip

  • @andrewtran9870
    @andrewtran9870 8 месяцев назад +1

    Woahhh, that's a mad enlightening take on typescript

  • @tigoes
    @tigoes 8 месяцев назад +3

    "typescript gives you illusion you have types"... so does C++ and every other language.

  • @ConnectionRefused
    @ConnectionRefused Год назад +2

    I love types now, but I used to do a lot of Ruby on Rails, and sometimes miss it...I could bang out a fully functional app (front end, back end, db, authentication, multiple data models, robust data validation and error handling) in a day or two.
    I spent most of yesterday debugging generic function signatures in TS 😶

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

      Same with django. Django is not easy to deploy tho

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

      @@rozennrd4802 Yeah I had a good experience with Django too, the built-in admin console was a great idea IMO. I've been meaning to try fastAPI, looks like maybe a happy medium between type safety + efficiency

  • @incremental_failure
    @incremental_failure Год назад +4

    The meaningful stuff does C, C++ or Rust in the background. And you can easily jit compile functions with Numba. Of course ideally you'd just use a fast language without all this need to optimise.

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

      Still much slower than native

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

      @@isodoubIet Not sure about the "much" part. Have you done any benchmarks? The benchmarks I've seen are using native Python to do operations on large arrays, which isn't really done with any serious software.
      For some of us, a rewrite in Rust would take years and it's simply not feasible. It's cheaper to simply buy compute power in most instances.

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

      @@incremental_failure "The benchmarks I've seen are using native Python to do operations on large arrays, which isn't really done with any serious software."
      Where people go wrong is when they measure the python overhead of their numpy solution and think they're close to native. The overhead of python may be small, but they're not accounting for the overhead of writing a solution nobody would've written natively. For example, if you write something like, a = b * c + d, numpy will create temporaries, whereas a native solution could make use of fused multiply-adds. Imagine doing this in a loop -- you could easily dwarf the cost of the numerical operations just with allocations.
      "Not sure about the "much" part."
      At my company we beat sklearn by like 10x without even trying. I think that qualifies as "much" faster.
      "For some of us, a rewrite in Rust w"
      There's no reason to reach for Rust when writing numerical software. C++ is a much better tool for that job and significantly easier to write.

  • @jly_dev
    @jly_dev 11 месяцев назад

    1. Certain implementations of Python have JIT. The mostly-used implementation, CPython, does not. PyPy does. There is also Cython for ahead-of-time compilation
    2. Python has optional typing. Because my company doesn't use TS, I get more static type safety in Python than I do in JavaScript 😂I maintain a handful or python projects, and all of them are >95% statically-typed.
    3. Polars, a Rust dataframe library with Python bindings, is really cool -- blazing fast (rust) and succinct (python)

  • @jackdra
    @jackdra Год назад +3

    When your training and predicting with machine learning models, the time "python" takes to execute the logic you wrote is negligible to the c binded code that you will run to actually perform the training/inference. Even on a GPU thought tensorflow/pytorch/etc.

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

      That may be technically true but you're not competing against your own code with the python parts removed. The relevant comparison is between the python solution and an equivalent native solution, and the latter will typically be much faster because you'll have to try really hard to make a native C/C++/Rust/Fortran solution as slow as what you'd get with numpy and friends.

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

      ​@@isodoubIetyou're changing the ask. The ask is to build an app that uses ML to trade stocks (say).
      Option 1 - use python + ML libraries (internally written in C++).
      Option 2 - Use C++/Rust
      You're claiming option 2 is you writing the python parts with C++/Rust and also writing the ML library! But it's not. You'll pick up an ML library and just use that.
      So what time/resources did you actually save by writing the glue code in C++/Rust?

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

    I never got the hype around TypeScript, precisely because it was ultimately just transpiled to JavaScript which has just massively bigger issues that lack of putting types next to vars. Granted, the same could be said about pretty much every other typed and compiled language "why bother with the type system in Rust" when it will just be compiled down to bytecode/assembly (which are almost type-less). And that's exactly why it makes more sense in a compiled language. Compiled. Not Transpiled.

  • @JoshuaB86
    @JoshuaB86 Год назад +5

    I love python. Never cared what other people would say... I get a lot done when using it.

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

      I don’t love it myself, but you hit the nail on the head “I get a lot done using it” if you do that & manage to not create a mess in the process, it’s the perfect language for the job

  • @DmitrijKudriavcev
    @DmitrijKudriavcev 11 месяцев назад +1

    Python is by far my favourite language. Writting code on it just feels pleasing. I'm not using it everywhere just becsuse it poor performance and outdated environment.
    If someone would create a go variant with python syntax instead of this bulky mess, it would instantly become my number uno language

  • @cheaterman49
    @cheaterman49 Год назад +20

    Large projects are just fine in Python :-) you use the gained productivity and saved time to implement robust tests, maybe type-hint absolutely everything, maybe have 100% coverage (I do the latter because type-hints aren't necessarily available for all the libs I use, but I'm also writing those on my spare time because I want everything typed, it helps) ; either way you can iterate on the product faster, meaning you also get better feedback, meaning you build a better product and everyone's happy - huge W as you noted!

    • @michaelmueller9635
      @michaelmueller9635 Год назад +3

      Note that you have to take 'type hints' by word. These are hints and optional. These do nothing for safety of your running code. Still with hints ...an int can be a string can be a float can be a char can be a chameleon...

    • @Blaisem
      @Blaisem Год назад +4

      If you're using the saved time to implement all the other stuff, then you probably would have been better off with basic java and enjoy a faster application.

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

      There are static analysis tools to make sure your types are sound. It's not perfect but it does help quite a bit.

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

      Yea but then you have to write Java… I fully admit that Python is kinda a really slow crap language but… I would pick Python over Java anyday.

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

      ​@@scythazz LOL. Agreed. Java is awful.

  • @MrAalrider
    @MrAalrider 6 месяцев назад

    Had a job interview with a company from the tourism industry that was planing the build a flightsearch backend with Python. They asked me about the Global Interpretator Lock in Python... never heared again of them

  • @culturedgator
    @culturedgator Год назад +4

    Golang feels like scripting TBH. Plus every other benefits and more when needed.
    Python is a great shell scripting lang. IMHO Posix should standardize on Python and replace the dangerous hell that is Bash scripts. Although Golang can do that too very nicely. Or at least Powershell.

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

      PowerShell is a godsend for shell activities. Bash can go off a cliff.

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

    The first 4.5 minutes are exactly why I code in Nim. It reads and writes like Python, so I'm able to get projects developed relatively quick, and it also has the performance of C++.

  • @tytywuu
    @tytywuu Год назад +4

    I mainly write Python. What I like about the type hinting in Python is that you can *choose* whether to sprinkle type annotations on your code and the common interpreter (CPython) does not enforce it, which means adding type annotation is just completely for your own good and readability. I am also a "typed" guy and this really boost my productivity. Of course if you like to get completely restricted like in TS you can use static type checker like mypy.

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

      On the other hand if you want to write TS and not be totally restricted, you can use a lenient tsconfig.

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

      Type _Annotations_ are such a good feature. There's zero value in writing adapters and converters just because "foo.bar.Person" is technically a separate type to "bar.foo.Person". Technically that's correct, but practically it's irrelevant (in the sense of a running program fulfilling business processes). Annotations provide all the good stuff, the IDE support, the documenation, without all that adapt/convert BS. But, just in case you like that sort of pain, there are ways to actually use type-enforcers and this kind of choice is great!

  • @Monkeydew1o2
    @Monkeydew1o2 7 месяцев назад +1

    Python has one advantage that is GREATLY overlooked. By being arguably the fastest language to develop in and the slowest language to run. It FORCES you to become extremely crafty with your code optimizations and due to ease of use. lets you trial and error to that point quickly.
    I used python to make a brokerage simulator.
    first run was so slow It couldn't be used. The current one is so fast I had to add implicit delays to not break rate limits.
    Skilled engineers trump the inherent weakness of a language by being better.

    • @OmarHashimOAD
      @OmarHashimOAD 6 месяцев назад

      good point

    • @resresres1
      @resresres1 4 месяца назад +1

      Reminds me when I was first learning Python. I would read excel files and manually loop through all the rows/columns with while loops and adding data to lists, which was slow. Then, I learned about Pandas and reading them to a dataframe, but i was still just while looping through the dataframe (still somewhat faster though). Learned about for loops around this time, instead of while loops. Then, I learned I didn't need to do loops at all, I could use pandas comprehensions on the dataframes and I also learned about vectorization methods on those dataframes. This sped things up MASSIVELY.

  • @onee
    @onee 5 месяцев назад +4

    I hate range in Python. It makes ZERO sense. Why would you write range like this. "I need 0 till 5 excluding 5, so I ACTUALLY need 0 till 4. Let's pretend like this makes sense."

    • @qlank9751
      @qlank9751 5 месяцев назад

      exclusive range?? skill issue

    • @snwtime
      @snwtime 4 месяца назад +2

      How to out yourself as having never written a C style for loop in your life

  • @kurtmayer2041
    @kurtmayer2041 11 месяцев назад +1

    > _pointing at APL_ can you argue with this?
    i really really can't because to argue with it i'd have to know what it's saying first

  • @billy818
    @billy818 Год назад +3

    python is my fav language tbh
    C, Rust and GO are my next 3 lol

  • @Sean-jg9sd
    @Sean-jg9sd 7 месяцев назад

    I would love LOVE to watch you develop something in TCL, especially if you’ve never heard of it until now

  • @thingsiplay
    @thingsiplay Год назад +2

    Python does not suck. Python is one of my favorite programming languages/environments. I have yet to find a perfect language.

    • @pranavtaysheti7858
      @pranavtaysheti7858 Год назад +2

      Try nim

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

      name me reason it does not suck
      here's my reasons why it sucks:
      - terrible performance
      - types can unwieldy the longer your program gets and the type checkers are very faulty at times
      - the GIL makes python play pretend that it's actually running on multiple threads but that actually never happens
      - optimizing python means reducing the amount of time your program is python, so you just end up installing and using a bunch of C libraries and if u do any sort of loop in python it slows your program down, this also means you have to spend time with a profiler checking where stuff is running on python land
      - bc of the way python is designed, if you copy a piece of code and u miss a single space your whole program will have a logic error and depending on where that space is that error might not even cause a easy to spot error so you might unknowingly be running a buggy program for a while until you get burnt by it
      - python abuses decorators and class inheritance to achieve some basic functionality available in other languages such as ordered dictionaries, enums, static methods, etc etc
      - package versioning is hell, you have to use the hacky (aka retrofitted) virtual environments and often times some other package manager like poetry cause pip just installs the library for the user or globally so you can break your whole system by updating a single package, which means a lot of distros end up shipping their own python libraries separately to avoid the user breaking their system
      - you simply cannot have ur program bundled from one system to another, there are "options" but they're all either dependent on you having pip installed (wheel) and will break if your python interpreter is the wrong version or you have to use something like pyinstaller or equivalent which result in big binaries that also take a while to load and might result in bad performance overall
      - expressions and list comprehensions are not optimal, the `x if x % 2 for x in range(100)` or whatever is just painful, if you need a complex set of expressions they're basically useless as they hurt readability, you might as well just use regular statements by then
      - lambdas are very lacking, lambdas in python are very limited, their inclusion changed very little in python, unless you're doing very simple maps, reduce, etc they're not very good since to write a more complex lambda you'd have to use the very sucky expressions and list comprehensions

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

      @@FlanPoirot There are tradeoffs with each programming language. If you use it properly for the use case it is designed for, then the language is good. Every language sucks at some point. You just listing some negative points does not mean the language sucks. It just means it is the wrong tool for you. I use Python since over a decade and it does not suck (but it does at some specific points).
      - performance is not terrible, it depends what you do with it
      - types is a weak point of the language, but a programming language does not consist only of types
      - threads, argument about GIL does not matte if it provides real benefits
      - optimizing Python does not mean reducing being Python, there are many ways to optimize, not only the one way you describe
      - buggy code is not the fault of Python, but your lack of testing
      - that Python uses decorators and inheritance to achieve basic functionality of other programs is a bad thing?
      - package versioning is a problem with almost every programming language, especially those of interpreted ones, but that is a problem if you are clueless and careless
      - list comprehensions are good and expressions might not be optimal, it's not a problem
      - lambdas are special cases, not a reason to avoid the language
      Looks like you are a Python hater. That's fine. Some of your points are nonsensical. I recommend to watch the video, so you understand why Python does not suck as people tell. I could write an essay about every language why it sucks. Python is a fantastic programming language with some weakness, but provides a lot of good stuff too. I have yet to find a programming language that is perfect and have no weak points.
      If you use Python for every possible use case, then its not the fault of the language, but its your fault to use the wrong tool. Rust, Haskell, Go, Zig, C, C++, each of these language suck. So we should stop using them? Which language does not suck in your opinion?

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

    Oh, I wholeheartedly agree that perl is winning in terms of how long it takes to solve a problem. It's just that the solution becomes a problem in of itself after an approximate 3 days of not having looked at the code, so while perl is fast at solving problems, it is by no means not capable of exacerbating the throughput of problems you need to solve just by its own nature.

  • @ulrich-tonmoy
    @ulrich-tonmoy Год назад +1

    we use typescript because the editor we use is not intelligent enough to give us what type of variable it is when we are using a variable declared on another file

  • @lukeli9588
    @lukeli9588 3 месяца назад +1

    To be fair, every language is an illusion on top of type less machine code.😂

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

    No. CPython (the main implementation of python, by the python foundation) doesn't have JIT. There are some niche runtimes that do, but amazingly, in most cases it's worse than CPython

  • @Ersteller
    @Ersteller 7 месяцев назад +1

    I feel one important aspect is missing in the video and the discussion. It is cross-platform. It takes some effort to do that with C/C++. Maybe not relevant for a Discord bot.
    If a Python program seems slow, most of the time it is because of the way the developer thought it had to be done.
    For instance, multiple levels of loops inside each other and looping over strings and searching for a keyword or adding it individually to another string which you would maybe do in C.
    It takes some time to get an intuition for what things are slow in Python but then you can avoid them and use appropriate built-in types like linked lists and hashmaps which are way better to work with in Python than buffers pointers and structs or classes.

  • @disgruntledtoons
    @disgruntledtoons 8 месяцев назад +1

    Python is the new BASIC. You use it for testing new ideas. If you need better performance, then you re-implement in a more performant language.

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

    "Median hours to solve a problem" also doesn't relate the type of the problem as well. It could be "hours to develop an interpreter" vs "hours to display hello world"