Arjan just wanted to let you know that in the past year your channel played a huge role in helping me get significantly better at programming during my final year of college, and now working as a software developer. You're doing great work!
Brother so happy to read this. The same thing happened to me as well four years ago and I'm so glad to see that the same thing happens to other people. Coding is the most empowering thing we can do
Last year I made a web scrapper that checked prices of products and used Object Oriented approach "just to keep the code organized". I did not have the need to spawn multiple instances of the scrapper and I was not storing anything in my scrapper instance, so I felt that I was using the wrong tool for the job, because there was no need to use any of the properties of an object, I was just calling its methods. Now it is much clearer to me why to pick one versus the another and I am very thankful that you made this video.
I recently discovered your channel and I can honestly say; the more I watch you and type out the codes you wrote... The better programmer I have become. THANK YOU!!
I have watched hour long lectures/presentations and read more articles than i care to count, on the pros and cons of OOP and using classes, and this is the first time I've seen someone sum it up so well. Honestly I could never figure out why anyone would ever use classes because they just seem to add a lot of complexity compared to the functionality they provide, so they always looked inferior to just using functions. This makes it so much easier to figure out where to use classes.
Classes are used to model nouns (objects): employees, products, customers, etc. This matches well with relational databases which are also designed around nouns. A product table with a unique ID for each product and a customer table with a unique ID for each customer.The state of the nouns are critical in the database. It is natural to use OOP to represent the entities stored in the database.
I agree, it sounds to me that objects are like tables in a database, actual structured data being manipulated on the fly, in the computer's working memory instead of non-volatile storage
I also find myself mixing the approaches quite often. In a web backend with routers, for example, I want both states (classes) and pure actions. Pure actions would be a crud module with action-focused SQL statements (or ORM code), while states would be a schema module with classes that hold the state of the request and response. Additionally, the ease of testing argument can not be said enough. The amount of mocking and pre-test setups you have to do varies significantly by the amount of state in your code. All in all, really great video, I agree with all points made.
I also find classes to be useful ways to hold data and define data structures (in this case, dataclasses), which can be passed in as arguments to functions and instances of classes. Thanks for another fantastic video Arjan.
I wouldn't count dataclasses as classes. Dataclasses are necessary in Python because there's no obvious way to define pure data: your choices in the standard library are dataclasses, named tuples and dicts, and dataclasses have the best ergonomics. They're much closer to pure structs.
Well described. I spent months coming to this conclusion, I wish I had your video when I started. One big reason I like to use functions with separate data structures, is that it can help to keep Inter Process Communication simple. I use a shared memory approach for performance and I think the OOP model (which tends to include exposing data) would be awkward in an IPC Python system.
Thanks for this, it makes a lot of sense. I wish I had seen this in my earlier days learning to code. I definitely have written code as classes when they should have been functions and written code as functions when they should have been classes.
Awesome content! As a self-taught programmer who first learnt functional programming, I often struggled to see the benefit of OOP. This is a super helpful framework for thinking about the differences between the two.
The duration of state is also an important factor. The rule can be formulated as follows: if you have state that needs to be retained for longer than one procedure call (and that state can be meaningfully encapsulated), then use a class. If the state is only needed for one procedure call, use a procedure .
The bank account example is ambiguous - irl want to use a transactional model with some backend data store. Unless you are the bank, the data isn’t mutated at your end, you send requests which are applied and the results are returned, ie; you don’t hold the object at your end.
My rule is: If it makes sense to encapsulate something in your own class (so interacting becomes easier and more intuitive), use classes, otherwise stick to functions.
I also have turned to this philosophy. Often times I would find myself writing 3-4 closely connected functions that require much of the same data and are unlikely to be used elsewhere throughout the program. While a function is theoretically a more robust construct to perform this task, the code becomes way more readable if I wrap it in a class and use the __call__ method to initiate the process.
@lukekurlandski7653 you can just encapsulate it in a module, though? The only reason to use a class is to encapsulate data. Otherwise functional, procedural or declarative are all better approaches. Honestly I would never call python code functional though, it's a language best used with the procedural style.
I don't even need to see the rest of the video but the intro, because you are so clear as allways. I will see it out pure fun and entertainment. Thanks 👍🙏
This channel is a gold mine. I'm a DBA and I use Python for simple automations, but I like to know the language more in depth and this channel seems perfect for it. Thanks for explaining the more high level concepts very clearly and with examples that I wouldnt easily find and I didnt get to study at uni not in this detail at least (I mainly did iteration algs in C and statistics with R no OOP)
I feel you can sometimes use classes to making functional programming cleaner. I was developing an automated report for work. The program would calculate some data, then either send a daily report or an invoice at the end of the month. Completely stateless, so a functional approach made sense. Different clients received their own version of the daily or monthly emails so we would need to write the same types of functions for each client. At the end of the day, it was simpler to create an interface which bundled all of these email-sending actions together. For each client, we used a different implementation of this interface. Technically it was an abstract class rather than an interface since Python doesn't have interfaces.
I taught myself python for tool creation for Maya and recently I was asked why I don't use classes as much as functions ( I barely use em). I didn't know how to answer but now having watched this has helped me wrap by brain around why, since my maya tools are mainly action oriented. Thanks for a great video!
Thanks. 12y ago I started programming Python and a big piece of administrative software for my business... Back then I really tried to use classes, because "that's how it's supposed to be". But found it was simpler if there was mostly plain functions. I did it that way, and it's still working everyday today. Now thanks to you I know I'm actually doing it right 👍🎉🎉🎉
As a Go developer I face the same challenge. Generally I start with functions, and find that I "step up" to data classes as needed. But truthfully, using both functions and data classes together is the answer. Personally I find data classes easier to test since they can implement interfaces, which allow for the easy creation of mock/fake implementations. Functions, on the other hand, can be harder to test, especially when they're coupled to other parts of the system. Also, in Go, a type introduces a new namespace/scope for its methods, which is valuable when the package you're working in is already heavily populated with functions. With no overloading of methods or functions, managing the namespace is critical.
Hi Arjan, thanks, for this video, i realize i don't have to use classes for everything if i want to programm, following "best practise", i think functions are easier to use and classes are more complicated. so if not needed i will stay with the functions.
Thx for this video. I am doing something like the first example you provided. I did a function oriented programme but decided to move to a object oriented one to look more professional. I feel what you said : it’s highly complex (but maybe I architectured it wrongly) and not as easy to read as functional based. I think I am going to roll back part of the code 🤔
I want to write a date convertion program but I don't know to use classes or functions, and I didn't get my answer from this video, you want to convert a date so it's action based so it should be with functions? And it would be state based if you wanted to store those dates? I'll appreciate who answers this.
functools.partial, which you have already covered in a few videos, is a great example of using functions to cover that "grey area" where you want to leverage some lightweight state but don't want the belt-and-braces approach of classes.
Same for me - Been moving onwards to functional programming recently and found myself struggling with certain aspects feeling more complicated than if i used classes. So this hybrid solution is what works the best for my imo.
Coding sensei, thank you for explaining the difference between class and functions. To confirm, if I wanted a code that monitored the stability of proteins over time, that would be state-focused, vs if I wanted to model the kinetics of protein binding, would that be more action-focused. please let me know if I am understanding.
Hello Arjan, I like to ask a question on type hints in Python. For example, @ 2:54, consider line 49: "column_name" is of type "str", "file" of type "DictReader" and "field_sep appears to be of particular type "str | None = None". The function returns an object of type "Counter[str]", i.e. "Counter" is being fed a list of strings. Question 1: How come "DictReader" is a file type at all and what is "str | None = None" supposed to mean?
Question 2: Can you please elaborate, or make a detailed video on advanced type hints. Using type hints is probably a big issues for lots of learners .I know you already have one out, but there seems to be much more on the topic. It would probably also fit nicely to a guide on how to use "pylint" effectively. Many thanks for your help.
Hi "hb bexxter", regarding your question 1, which actually holds 2 'sub'-questions, here is my 2 cents. The DictReader class is defined in the csv module from the Python Standard Library. I would not call it a 'file type'. It is a type hint stating that the argument named "file" has that type. As the documentation of DictReader explains it is a class that implements iteration and at each iteration a dict is returned. And that is exactly what you see in the implementation of the function where it reads "for line in file:". And then, on the next line, you can see confirmed that the loop variable "line" is indeed used as a dictionary since it is indexed by a column name. Regarding your 2nd 'sub'-question: in "str | None = None" the part before the '=' is the type-hint which states that argument field_sep is either a str(ing) or None. A slightly older form of this type-hint would be "Optional[str]". And finally, the part "= None" (so after the type hint) states that the default value of argument field_sep is None. I.e., if the function cumulative_count would be called with only one argument (being the actual value for argument file) then the value None would be used for argument field_sep. I hope this helps you further.
I have a question about basic programming structures. I have a series of functions that access different databases. I’m not using APIs or json requests, but direct connections, think of them as simple spreadsheets. Function 1 hits database 1 and for those records that meet the criteria, I return values from columns A, C, D, and G. What is the pythonic or professional way to return? I’ve got multiple rows that meet the criteria. I’ve tried tuples of lists, dictionaries of tuples, e.g. return [row1 : (A, C, D, G)] … and returned a dict of subdicts [row1 : [A:value], [C:value]…] They all work but retrieving values by index or keys:subdict key seems convoluted. Thanks!
Thanks, Arjan. A question: Say I take a class, make all its instance methods return "self", and then just take them out of the class and convert them into functions. After this, the class is left with only attributes that represent state, and no behavior. What are some good arguments against doing this? I can think of one, which is it can make it harder to quickly read which functions "go together with" which data, loosely speaking. But I'm curious to know if people have other reasons.
Great video! comming from pure object-oriented languages to Python I've always struggled to know when to choose just functions over classes, I still have a question though. What about classes that act as a container for multiple related actions? for example, having a class responsible for file utilities, getting a file's absolute path, basename, extension, .... you name it. Would it be better to have file utils as a file containing those functions or have them inside a FileUtils class and mark those methods @staticmethod?
8:15 (in python) couldn't you just use a list of dicts? that's only 1 variable and basically does the job of a class (and of course in reality you'd just be using a db)
If we begin writing a program, initially we think is state focused, but end up with lots of static methods...would this be a signal that in fact our program is action focused and should switch to pure functions?
@@Geza_Molnar_ well... I've doing uml diagrams since then really hahaha never face this question anymore, however, if is not the case and I haven't done any diagrams, lots of static methods should be a signal to migrate the module to functions
What I don't get, is how classes are supposed to "store" these states/data/transactions. I assume you'de have to pass every transaction to a database, for example MS SQL?
Hey ChatGPT, can you summarize the following video and focus on the code examples it used? """ Sure, in the video, the speaker provides two examples to illustrate when to use functions versus classes. In the first example, the speaker demonstrates a simple program that analyzes data from a CSV file. The program has a few functions that take input arguments, do something with the data, and then return a result. These functions are then called in a specific order to carry out the analysis. In this case, the program is action-focused, and functions are the most suitable choice for organizing the code. In the second example, the speaker demonstrates a program that simulates a simple game of blackjack. In this case, the program needs to maintain state information such as the player's hand, the dealer's hand, and the deck of cards. The program also needs to have methods that modify this state such as dealing cards and checking for a win. In this case, the program is state-focused, and classes are a better choice for organizing the code. Overall, the examples demonstrate that functions are best suited for action-focused programs, while classes are better for state-focused programs. However, it's important to note that there is no hard and fast rule, and the choice between functions and classes ultimately depends on the specific requirements of the program. """
For me I prefer the more data oriented approach where data is first class citizen, for more back end application. I personally believe this approach give clear definitions between the layers and void a lot of mocking and stubbing if it more data centric. Though I do like using my own types h i.e data class etc. For python libs I go more OO seems reasonable to when creating a lib.
Have been looking for an answer for this question for long time and just wanted to ask you one hour ago…. Also another question: how can we organize and/or import multiple functions and classes better in py file(s)?
State-focused programming is ill advised, especially for bigger more complex code. My suggestion: avoid mutable state like the plague. Classes are still very useful though, even if their attributes don't get mutated: classes model data, encapsulate properties (read-only) and encapsulate functionality bound to this data (like closures). I think of classes as (1) immutable structs that can have calculated fields or (2) parameterized modules. Functions can tempt you to call global objects or global configuration, which are then difficult to factor out when you need to switch those objects. Classes can tempt you to mutate the object state, which after a few hundred lines looks a lot like mutating globals. So basically, avoid side effects.
Software is all about side effects. There is not much benefit for a software which does not mutate state. At the end of a workflow, you still need to persist the mutated state in a database, file, etc.
so often i was asked if i do object oriented or what style i code in and i never knew what i did.... apparently i write funtion oriented code. my code just does things
You know I really like this explanation. Too often I find videos where OOP is decried as demonic and you can get away with using functions for most OOP uses.
I'm really confused. How come your code has those arrows ( -> ) in it? How come python doesn't error with those? I've never seen those arrows before in the videos I've watched.
The decision is usually intuitive: pure functions become the obvious choice if you minimise state. In the cases where you _need_ state (and if you're careful about your design, you'll realise that there aren't many), introduce classes, but be very careful about how you present this state to the outside world. My code is primarily dataclasses (or TypedDicts if I can't help it) and functions that operate on them, with a few classes here and there when state is unavoidable.
Why wouldn't something require state? I work in firmware, motor control, and everything I am used to is managing state, encoders, tachometer, dynos, prechargers, igbts.... it's all very stateful.
It depends on what you consider as state. I'd argue that any data you pass as arguments to functions or return from functions represents state. A number passed as argument to a function represents some state somewhere in your system.
I've been writing code for about... oh... when playing in the dirt was good clean fun. The classes stuff is not sinking in. In the backing app; the class only lives for a given time as the single account updates are complete? In the example, the init set the value of the balance to zero. In real life, something would have to feed the current balance to the init part. Calling program open transaction file. Sets the starting balance for this account. How would the class get and keep the balance for this account? Then a loop to process all the updates for this account Call class Save the updated balance get next account So, we basically have two programs, the driver and the class. I'm still not getting the need for a class, when a function can do the same thing and be contained in one program. Not trying to be critical, trying to understand as my attempt to use classes seem to fail and I have to revert it back to a function. I know and have uses a program that call other programs, but that/those called programs do very little and always need some program to drive the process. Please help.
Classes and functions are not programs but are components that you can use in making programs. Class defines the object, its properties(data), and methods(what you can do with said data). Functions typically describes "actions" in programs. When making a program you can use just functions but you will have to track all the data yourself(doable, think games made in C). However, if you are dealing with large amount of related data that are structured, using classes makes development mentally easier.
👷 Join the FREE Code Diagnosis Workshop to help you review code more effectively using my 3-Factor Diagnosis Framework: www.arjancodes.com/diagnosis
Arjan just wanted to let you know that in the past year your channel played a huge role in helping me get significantly better at programming during my final year of college, and now working as a software developer. You're doing great work!
Thank you for sharing this!
Brother so happy to read this. The same thing happened to me as well four years ago and I'm so glad to see that the same thing happens to other people. Coding is the most empowering thing we can do
Last year I made a web scrapper that checked prices of products and used Object Oriented approach "just to keep the code organized". I did not have the need to spawn multiple instances of the scrapper and I was not storing anything in my scrapper instance, so I felt that I was using the wrong tool for the job, because there was no need to use any of the properties of an object, I was just calling its methods. Now it is much clearer to me why to pick one versus the another and I am very thankful that you made this video.
This has been my question for YEARS! Thanks for making it simple, love your videos.
It is one the most simple and useful explanations of the difference between function/class usage cases
Lots of thanks!
I just can not believe how every line of code in your videos is useful and worth to even dive deeper in the logic you create! Best of the best!
Thank you so much!
I recently discovered your channel and I can honestly say; the more I watch you and type out the codes you wrote... The better programmer I have become. THANK YOU!!
Wow, thank you!
@2:35 I love it when Arjan always says: "I have a very simple sample application here"
Me: Eyes squinting: I have no clue what this does
I have watched hour long lectures/presentations and read more articles than i care to count, on the pros and cons of OOP and using classes, and this is the first time I've seen someone sum it up so well. Honestly I could never figure out why anyone would ever use classes because they just seem to add a lot of complexity compared to the functionality they provide, so they always looked inferior to just using functions. This makes it so much easier to figure out where to use classes.
Thank you!
Arjan is a one-man university.
Someone didn't go to university
Not enough committees to be accredited though.
I would say also for a dev he’s extremely proficient at marketing.
Word!
LMAO
Classes are used to model nouns (objects): employees, products, customers, etc.
This matches well with relational databases which are also designed around nouns. A product table with a unique ID for each product and a customer table with a unique ID for each customer.The state of the nouns are critical in the database. It is natural to use OOP to represent the entities stored in the database.
Is there any Subject in programming ?
I agree, it sounds to me that objects are like tables in a database, actual structured data being manipulated on the fly, in the computer's working memory instead of non-volatile storage
I also find myself mixing the approaches quite often. In a web backend with routers, for example, I want both states (classes) and pure actions. Pure actions would be a crud module with action-focused SQL statements (or ORM code), while states would be a schema module with classes that hold the state of the request and response.
Additionally, the ease of testing argument can not be said enough. The amount of mocking and pre-test setups you have to do varies significantly by the amount of state in your code.
All in all, really great video, I agree with all points made.
I also find classes to be useful ways to hold data and define data structures (in this case, dataclasses), which can be passed in as arguments to functions and instances of classes. Thanks for another fantastic video Arjan.
Totally agree & you’re welcome, Ross!
I wouldn't count dataclasses as classes. Dataclasses are necessary in Python because there's no obvious way to define pure data: your choices in the standard library are dataclasses, named tuples and dicts, and dataclasses have the best ergonomics. They're much closer to pure structs.
Well described. I spent months coming to this conclusion, I wish I had your video when I started. One big reason I like to use functions with separate data structures, is that it can help to keep Inter Process Communication simple. I use a shared memory approach for performance and I think the OOP model (which tends to include exposing data) would be awkward in an IPC Python system.
I love your humor. You are literally a meme guy.
Thank you so much for your hard work and contribution to the Python community
You're welcome - glad you find it helpful! Now... I have to go back to creating memes ;).
Thanks for this, it makes a lot of sense. I wish I had seen this in my earlier days learning to code. I definitely have written code as classes when they should have been functions and written code as functions when they should have been classes.
Awesome content! As a self-taught programmer who first learnt functional programming, I often struggled to see the benefit of OOP. This is a super helpful framework for thinking about the differences between the two.
Thank you, Morgan!
The duration of state is also an important factor. The rule can be formulated as follows: if you have state that needs to be retained for longer than one procedure call (and that state can be meaningfully encapsulated), then use a class. If the state is only needed for one procedure call, use a procedure .
agreed, with the bank account example one could easily handle the state in a file or database, and have all the operations be functional
This is a pretty sound generalization.
very helpful
The bank account example is ambiguous - irl want to use a transactional model with some backend data store. Unless you are the bank, the data isn’t mutated at your end, you send requests which are applied and the results are returned, ie; you don’t hold the object at your end.
Thank you. You are definitely helping me look at the broad picture and not focus on the code so much.
Happy to help!
My rule is: If it makes sense to encapsulate something in your own class (so interacting becomes easier and more intuitive), use classes, otherwise stick to functions.
I also have turned to this philosophy. Often times I would find myself writing 3-4 closely connected functions that require much of the same data and are unlikely to be used elsewhere throughout the program. While a function is theoretically a more robust construct to perform this task, the code becomes way more readable if I wrap it in a class and use the __call__ method to initiate the process.
@lukekurlandski7653 you can just encapsulate it in a module, though? The only reason to use a class is to encapsulate data. Otherwise functional, procedural or declarative are all better approaches.
Honestly I would never call python code functional though, it's a language best used with the procedural style.
I don't even need to see the rest of the video but the intro, because you are so clear as allways. I will see it out pure fun and entertainment. Thanks 👍🙏
This channel is a gold mine. I'm a DBA and I use Python for simple automations, but I like to know the language more in depth and this channel seems perfect for it. Thanks for explaining the more high level concepts very clearly and with examples that I wouldnt easily find and I didnt get to study at uni not in this detail at least (I mainly did iteration algs in C and statistics with R no OOP)
Glad you enjoy it!
I feel you can sometimes use classes to making functional programming cleaner. I was developing an automated report for work. The program would calculate some data, then either send a daily report or an invoice at the end of the month. Completely stateless, so a functional approach made sense. Different clients received their own version of the daily or monthly emails so we would need to write the same types of functions for each client. At the end of the day, it was simpler to create an interface which bundled all of these email-sending actions together. For each client, we used a different implementation of this interface. Technically it was an abstract class rather than an interface since Python doesn't have interfaces.
hi, python has protocol that can be used as interfaces, Arjan has a video about abstract classes vs protocols
I can't to be good like you Arjan. Thanks for the effort. Keep up the good work!
Amazing cosmically music, good light. I almost fly away to the andromeda. Thanks
I taught myself python for tool creation for Maya and recently I was asked why I don't use classes as much as functions ( I barely use em). I didn't know how to answer but now having watched this has helped me wrap by brain around why, since my maya tools are mainly action oriented. Thanks for a great video!
I'm happy to hear the video helped out!
Thanks. 12y ago I started programming Python and a big piece of administrative software for my business... Back then I really tried to use classes, because "that's how it's supposed to be". But found it was simpler if there was mostly plain functions. I did it that way, and it's still working everyday today. Now thanks to you I know I'm actually doing it right 👍🎉🎉🎉
Awesome! Thank so for sharing this!
Thank you, ArjanCodes!
Glad you enjoyed the content!
As a self-taught coding person (though far from expert), I have often asked myself this question. Thanks for a great perspective on it.
What an outstanding video. It even make sense when you're questioning if it makes sense.
I'm glad you enjoyed the video!
The intro is perfect :D love your content and your humble attitude.
Thank you so much! :)
As a Go developer I face the same challenge. Generally I start with functions, and find that I "step up" to data classes as needed. But truthfully, using both functions and data classes together is the answer. Personally I find data classes easier to test since they can implement interfaces, which allow for the easy creation of mock/fake implementations. Functions, on the other hand, can be harder to test, especially when they're coupled to other parts of the system.
Also, in Go, a type introduces a new namespace/scope for its methods, which is valuable when the package you're working in is already heavily populated with functions. With no overloading of methods or functions, managing the namespace is critical.
Perfectly explained, I loved this
Thank you, Kyle!
Arjan, you inspired me to dive deeper into python and made me want to get better at it! Good stuff. Kudos!!!!
Thank you!
0:36 - Nice B5 reference!
Hi Arjan, thanks, for this video, i realize i don't have to use classes for everything if i want to programm, following "best practise", i think functions are easier to use and classes are more complicated. so if not needed i will stay with the functions.
Valuable insights as always!
Thank you Scott!
Thanks for sharing. It really helps
Thank you for making this video.
Glad you liked it!
I love this framework! One more: if your program is process-focused, that’s when you use an imperative style
Great advice, thanks for sharing!
Glad you enjoyed it, John!
Thx for this video. I am doing something like the first example you provided.
I did a function oriented programme but decided to move to a object oriented one to look more professional. I feel what you said : it’s highly complex (but maybe I architectured it wrongly) and not as easy to read as functional based. I think I am going to roll back part of the code 🤔
One more notch in the programming Swiss Army Knife. Thanks.
Listening to you is like listening to the best senior developer that never existed in my company.
The Babylon 5 reference is Awesome! Really takes me back.
Hopefully this video is relevant for more than a few more years. Eventually the correct decision will be whatever GPT-5 decides.
You are already there.
I want to write a date convertion program but I don't know to use classes or functions, and I didn't get my answer from this video, you want to convert a date so it's action based so it should be with functions? And it would be state based if you wanted to store those dates? I'll appreciate who answers this.
Very helpful, thanks
Glad it was helpful!
Perfect explanation.
Thank you, Michael, glad you liked it!
Thank you for the content!
Just subscribed because i really need this knowledge in video. Hopefully I can gain more after subscribing !
Glad to hear you like the content, and welcome on board! ;)
Exact tutorial i was looking ❤. Thanks
Enjoy the video!
functools.partial, which you have already covered in a few videos, is a great example of using functions to cover that "grey area" where you want to leverage some lightweight state but don't want the belt-and-braces approach of classes.
Well done, thx!!
Finding out about classes is almost the same “omg” revelation moment as when you first find out about Python 😅 dope vid
thanks for the overview.
Glad you enjoyed the video!
Are you spying on me. Seriously you come up with topics which I recently search😊❤
Same for me - Been moving onwards to functional programming recently and found myself struggling with certain aspects feeling more complicated than if i used classes. So this hybrid solution is what works the best for my imo.
Very nice explanation....
Coding sensei, thank you for explaining the difference between class and functions. To confirm, if I wanted a code that monitored the stability of proteins over time, that would be state-focused, vs if I wanted to model the kinetics of protein binding, would that be more action-focused. please let me know if I am understanding.
Goeie video Arjan!
Can't go wrong with functions, its that easy.
Great video thank you
Liked for the B5 reboot reference!!!
I prefer this kind of content, over videos of his studio or equipment.
Hello Arjan,
I like to ask a question on type hints in Python.
For example, @ 2:54, consider line 49:
"column_name" is of type "str", "file" of type "DictReader" and "field_sep
appears to be of particular type "str | None = None". The function returns an object of type "Counter[str]", i.e. "Counter" is being fed a list of strings.
Question 1: How come "DictReader" is a file type at all and what is "str | None = None" supposed to mean?
Question 2: Can you please elaborate, or make a detailed video on advanced type hints.
Using type hints is probably a big issues for lots of learners .I know you already have one out, but there seems to be much more on the topic. It would probably also fit nicely to a guide on how to use "pylint" effectively.
Many thanks for your help.
Hi "hb bexxter", regarding your question 1, which actually holds 2 'sub'-questions, here is my 2 cents.
The DictReader class is defined in the csv module from the Python Standard Library. I would not call it a 'file type'. It is a type hint stating that the argument named "file" has that type. As the documentation of DictReader explains it is a class that implements iteration and at each iteration a dict is returned. And that is exactly what you see in the implementation of the function where it reads "for line in file:". And then, on the next line, you can see confirmed that the loop variable "line" is indeed used as a dictionary since it is indexed by a column name.
Regarding your 2nd 'sub'-question: in "str | None = None" the part before the '=' is the type-hint which states that argument field_sep is either a str(ing) or None. A slightly older form of this type-hint would be "Optional[str]".
And finally, the part "= None" (so after the type hint) states that the default value of argument field_sep is None. I.e., if the function cumulative_count would be called with only one argument (being the actual value for argument file) then the value None would be used for argument field_sep.
I hope this helps you further.
@@jurgenrusch4041 many thanks Jurgen, for your great explanation and being such a proactive member of the community.
I have a question about basic programming structures.
I have a series of functions that access different databases. I’m not using APIs or json requests, but direct connections, think of them as simple spreadsheets. Function 1 hits database 1 and for those records that meet the criteria, I return values from columns A, C, D, and G. What is the pythonic or professional way to return? I’ve got multiple rows that meet the criteria. I’ve tried tuples of lists, dictionaries of tuples, e.g.
return [row1 : (A, C, D, G)] … and returned a dict of subdicts [row1 : [A:value], [C:value]…]
They all work but retrieving values by index or keys:subdict key seems convoluted.
Thanks!
God bless!, thank you for you knowleadge
You’re welcome - glad you find it helpful!
But what do you mean by 'state'?
Great intro!
Thanks, Arjan. A question: Say I take a class, make all its instance methods return "self", and then just take them out of the class and convert them into functions. After this, the class is left with only attributes that represent state, and no behavior. What are some good arguments against doing this? I can think of one, which is it can make it harder to quickly read which functions "go together with" which data, loosely speaking. But I'm curious to know if people have other reasons.
Great video! comming from pure object-oriented languages to Python I've always struggled to know when to choose just functions over classes, I still have a question though.
What about classes that act as a container for multiple related actions? for example, having a class responsible for file utilities, getting a file's absolute path, basename, extension, .... you name it. Would it be better to have file utils as a file containing those functions or have them inside a FileUtils class and mark those methods @staticmethod?
I learned more by just hearing than by just watching the video. For me there is too much information in short term by watching it.
Arjan is extra witty today. 😜
09:09 line 49 what tuple[a, b, c] means?
1:30 Not only Haskell :)
```
def say_something():
print("something")
def func_handler(func_par):
func_par()
func_handler(say_something)
```
what’s your lighting budget? love the hues in your videos.
He made a whole video about his set-up, you should probably start there.
8:15 (in python) couldn't you just use a list of dicts? that's only 1 variable and basically does the job of a class
(and of course in reality you'd just be using a db)
thank you
Thank you.
What about mixing functional with oop?
Classes makes it easy to collect belonging functions. What’s good strategy there when using functions to not end up with everything together?
If we begin writing a program, initially we think is state focused, but end up with lots of static methods...would this be a signal that in fact our program is action focused and should switch to pure functions?
I'm going to provoke you : What's the reason you begin writing program, and not begin drawing diagrams before that?
@@Geza_Molnar_ well... I've doing uml diagrams since then really hahaha never face this question anymore, however, if is not the case and I haven't done any diagrams, lots of static methods should be a signal to migrate the module to functions
What I don't get, is how classes are supposed to "store" these states/data/transactions. I assume you'de have to pass every transaction to a database, for example MS SQL?
Hey ChatGPT, can you summarize the following video and focus on the code examples it used?
"""
Sure, in the video, the speaker provides two examples to illustrate when to use functions versus classes.
In the first example, the speaker demonstrates a simple program that analyzes data from a CSV file. The program has a few functions that take input arguments, do something with the data, and then return a result. These functions are then called in a specific order to carry out the analysis. In this case, the program is action-focused, and functions are the most suitable choice for organizing the code.
In the second example, the speaker demonstrates a program that simulates a simple game of blackjack. In this case, the program needs to maintain state information such as the player's hand, the dealer's hand, and the deck of cards. The program also needs to have methods that modify this state such as dealing cards and checking for a win. In this case, the program is state-focused, and classes are a better choice for organizing the code.
Overall, the examples demonstrate that functions are best suited for action-focused programs, while classes are better for state-focused programs. However, it's important to note that there is no hard and fast rule, and the choice between functions and classes ultimately depends on the specific requirements of the program.
"""
I'm learning Python just to get Babylon 5 reboot. I don't know how that'll happen, but I have faith in arjan lol
For me I prefer the more data oriented approach where data is first class citizen, for more back end application. I personally believe this approach give clear definitions between the layers and void a lot of mocking and stubbing if it more data centric. Though I do like using my own types h i.e data class etc. For python libs I go more OO seems reasonable to when creating a lib.
it sounds to me objects are more suitable when we have to store and manipulate data during the program/system execution, i am right @arjancodes ?
Have been looking for an answer for this question for long time and just wanted to ask you one hour ago…. Also another question: how can we organize and/or import multiple functions and classes better in py file(s)?
Comments. Use them.
If your editor/language allows region comments, use those.
I like to group tasks, if they are complex, and data into classes.
"Clean code saves the world!"
yay, another B5 fan
State-focused programming is ill advised, especially for bigger more complex code. My suggestion: avoid mutable state like the plague. Classes are still very useful though, even if their attributes don't get mutated: classes model data, encapsulate properties (read-only) and encapsulate functionality bound to this data (like closures). I think of classes as (1) immutable structs that can have calculated fields or (2) parameterized modules. Functions can tempt you to call global objects or global configuration, which are then difficult to factor out when you need to switch those objects. Classes can tempt you to mutate the object state, which after a few hundred lines looks a lot like mutating globals. So basically, avoid side effects.
Software is all about side effects. There is not much benefit for a software which does not mutate state. At the end of a workflow, you still need to persist the mutated state in a database, file, etc.
is the diagnosis page not working ? unable to sign up
so often i was asked if i do object oriented or what style i code in and i never knew what i did.... apparently i write funtion oriented code. my code just does things
The stakes couldn’t be higher. B5 is a great show
You know I really like this explanation. Too often I find videos where OOP is decried as demonic and you can get away with using functions for most OOP uses.
I'm really confused. How come your code has those arrows ( -> ) in it? How come python doesn't error with those? I've never seen those arrows before in the videos I've watched.
And what about "batch"... They are actions to change the state... so, classes or functions ?
Classes are great for Polymorphism which helps write code that follow solid principles like open closed and others.
The decision is usually intuitive: pure functions become the obvious choice if you minimise state. In the cases where you _need_ state (and if you're careful about your design, you'll realise that there aren't many), introduce classes, but be very careful about how you present this state to the outside world.
My code is primarily dataclasses (or TypedDicts if I can't help it) and functions that operate on them, with a few classes here and there when state is unavoidable.
Why wouldn't something require state? I work in firmware, motor control, and everything I am used to is managing state, encoders, tachometer, dynos, prechargers, igbts.... it's all very stateful.
It depends on what you consider as state. I'd argue that any data you pass as arguments to functions or return from functions represents state. A number passed as argument to a function represents some state somewhere in your system.
I've been writing code for about... oh... when playing in the dirt was good clean fun. The classes stuff is not sinking in. In the backing app; the class only lives for a given time as the single account updates are complete?
In the example, the init set the value of the balance to zero. In real life, something would have to feed the current balance to the init part.
Calling program open transaction file.
Sets the starting balance for this account. How would the class get and keep the balance for this account?
Then a loop to process all the updates for this account
Call class
Save the updated balance
get next account
So, we basically have two programs, the driver and the class. I'm still not getting the need for a class, when a function can do the same thing and be contained in one program. Not trying to be critical, trying to understand as my attempt to use classes seem to fail and I have to revert it back to a function. I know and have uses a program that call other programs, but that/those called programs do very little and always need some program to drive the process. Please help.
Classes and functions are not programs but are components that you can use in making programs. Class defines the object, its properties(data), and methods(what you can do with said data). Functions typically describes "actions" in programs.
When making a program you can use just functions but you will have to track all the data yourself(doable, think games made in C). However, if you are dealing with large amount of related data that are structured, using classes makes development mentally easier.