Transcript #214: Python year in review (2020 edition)
Return to episode page view on github00:00 Hey everyone, 2020 has been quite the year, hasn't it?
00:03 Definitely one of those for the history books.
00:05 So over on Talk Python to me, I did a year in review show and it actually had me and Brian
00:11 on there along with a bunch of other really great guests who have been on this show and
00:16 on Talk Python before.
00:18 So I thought what we could do for our year in review here is to bring you that same show,
00:22 to bring you that same conversation.
00:24 In fact, it was more in the style of Python Bytes than it was Talk Python to be honest.
00:28 So I think it belongs here.
00:30 So without further ado, let's join that conversation where we look back on 2020 with Cecil Phillip,
00:37 Ines Montani, Jay Miller, Paul Everett, Reuven Lerner, Matt Harrison, Brian Okken, and me.
00:42 Enjoy the show and thank you so much for listening to Python Bytes this year.
00:46 We'll see you in 2021.
00:47 So let's go ahead and just kick off this episode.
00:51 This one is a little bit different than the standard show.
00:53 Everyone here has been a guest and a great guest and some of you even repeat guests.
00:58 Some of you are a repeat guest and scheduled for more episodes even, hint, hint, Ines.
01:02 But let's go ahead and kick it off.
01:04 So this is going to be a year in review.
01:05 There's a bunch of us here, seven or eight of us.
01:08 And I'll just do a quick introduction.
01:10 Let me just welcome you individually on.
01:12 You could say, you know, a couple sentences about who you are and whatnot so people know.
01:16 And then we're just going to get into what you thought was the most interesting, impactful
01:20 thing of the year.
01:21 And I have some software to help me do this.
01:23 So let me run it here.
01:24 Darn it.
01:24 It's me.
01:25 All right.
01:25 We'll go back to that.
01:26 Well, let me welcome you all.
01:28 Then we'll go through this.
01:29 So Jay, Jay Miller, welcome to Talk By The Me again.
01:32 Happy to be here.
01:33 I haven't been a guest in like three years.
01:35 So I know, but your episode was so popular.
01:38 Like over a hundred thousand people listen to your episode.
01:40 Can you believe that?
01:40 That's so insane.
01:41 I'm shutting down my podcast.
01:43 I don't get those kind of listens.
01:46 Tell people about yourself.
01:47 Sure.
01:48 Jay Miller.
01:49 I'm a podcaster, developer, now developer advocate for Elastic.
01:53 You know, the people that do search and we are database shots again, Michael.
01:58 But yeah, I'm just happy to be here.
02:02 Yeah, that's it.
02:03 Awesome.
02:03 Welcome.
02:04 Reuven Lerner.
02:05 Welcome back.
02:06 Good to see you, man.
02:07 Hey there.
02:07 Nice to be here.
02:07 How early is it?
02:09 It's not that early.
02:10 It's only 530.
02:10 Oh, okay.
02:11 Well, thank you so much for waking up early and making.
02:13 Yeah, we have people from basically every corner of the world.
02:17 So yeah, tell people about yourself again, if they haven't heard the episodes.
02:20 Sure.
02:20 So I'm a Python trainer.
02:22 So most days I'm in different companies doing on-site training.
02:27 Nowadays, a little less on-site for some strange reason.
02:29 And so I normally do corporate training, everything from intro to Python for non-programmers all
02:34 the way up to advanced Python workshops.
02:35 And I also sell a whole bunch of courses online to individuals.
02:38 Oh, and I have my book.
02:40 My book, Python Workout.
02:41 Yay.
02:42 Yeah, and we're streaming live with video.
02:44 So you can hold it up.
02:45 Yeah, that's awesome.
02:46 Oh, I can hold it up.
02:47 Python Workout.
02:49 Awesome.
02:49 And it's the picture of me on the cover, of course.
02:50 Of course.
02:51 Yeah.
02:51 That was when you were working out, preparing for the Olympics.
02:53 Precisely.
02:54 Precisely.
02:54 Yeah, exactly.
02:55 So we'll be sure to link to your book and some of your courses as well.
02:58 Ines, welcome from the other side of the world.
03:01 Yeah, I'm currently in Australia.
03:03 Escaped the EU lockdowns.
03:06 And now I'm here.
03:06 Yeah, happy to be back.
03:07 I think I've been on a few of your podcasts.
03:09 But it's always my favorite podcast.
03:11 Oh, thank you.
03:11 Yeah, it's awesome to have you here.
03:14 And I have definitely dreamed about, well, my daughter goes to school online.
03:18 I always work online.
03:20 Maybe we should just go somewhere by a beach away from people.
03:23 How can we do that where it's warm?
03:24 Right?
03:24 And it seems like you pulled it off.
03:26 Beautiful.
03:26 All right, Paul.
03:27 Paul Everett, welcome.
03:28 I just saw Anthony Shaw talking.
03:30 So if you want to talk about converting your life to work at the beach, just subscribe to his damn Twitter account.
03:36 Welcome, Anthony Shaw.
03:37 Anthony, I'm raging against you.
03:39 Oh, my gosh.
03:40 Also from Australia.
03:41 Hey, Anthony.
03:41 And Andrew from PyCharm is here.
03:44 A bunch of folks.
03:45 Mark, awesome.
03:45 Paul, introduce yourself.
03:47 Sure.
03:47 Developer advocate at JetBrains for Python stuff and web stuff.
03:51 Most known for giving the Python 1994 talk.
03:54 My purpose on this panel is to increase the median age so that we all qualify for the discount at the buffet.
04:01 Hey, man.
04:02 I'm right there with you.
04:02 Right there with you.
04:03 Awesome.
04:03 Nice to have you, Paul.
04:04 Brian, we've met before, right?
04:06 Yeah.
04:07 Brian Okken, he and I co-host Python Bytes Together.
04:11 And you've been on the show quite a few times as well.
04:13 Last time, I think we covered 30 pytest plugins.
04:15 That was quite the whirlwind tour.
04:17 Yeah.
04:17 So I highly recommend this book to anybody that wants to learn pytest.
04:20 Awesome.
04:21 Matt Harrison, welcome back.
04:22 Thanks.
04:23 Good to be here.
04:23 I guess I'm similar to Reuben.
04:26 I do corporate training and consulting in Python and data science.
04:29 And I guess since we're flaunting books, I'll flaunt my latest book.
04:33 Wait, wait.
04:34 The tiny Python 3 notebook.
04:35 Awesome.
04:36 Tiny Python notebook.
04:36 It's very small.
04:37 Anyway.
04:38 It is tiny.
04:39 Well, what I was going to say, Matt, is like, you're going to need to be like basically an octopus to hold up all your books.
04:43 Like multiple books on each tentacle.
04:45 I've got a few here.
04:47 So yeah, it's good to be here.
04:48 Thanks for having me on.
04:49 Yeah.
04:49 Yeah.
04:49 You were just recently on about learning how to learn.
04:52 Yeah.
04:52 Does it count if I have everyone else's book?
04:55 Yes, it does.
04:55 But it would also be hard to hold them all up, especially if you got all of Matt's.
04:58 Cecil Phillip, man.
05:00 Hello.
05:01 Good to see you, friend.
05:01 Hey, thanks for having me on.
05:03 I don't have any books to share, but because I hate writing.
05:06 So I don't write anything.
05:07 I do do some video.
05:08 So if y'all are interested.
05:10 I do do a weekly Python stream on Wednesdays.
05:13 So if you folks want to check it out, it's on Twitch at the Microsoft developer account.
05:17 And we do very beginner friendly conversations about Python and stuff like that.
05:22 And Michael, you were just on the other day too, right?
05:24 Yeah.
05:24 It was so fun to be on there with you.
05:25 We got to play around with FastAPI.
05:27 And man, that's a cool framework.
05:28 So it's Coding from the Beach.
05:30 What's the name of the show?
05:31 That's a good name, actually.
05:32 Maybe I should coin that one.
05:33 No, so we do Pi Weekly.
05:36 So it's me and my coworker, Brian Clark.
05:39 And we kind of approach Python from the perspective of beginners, but also from two people that
05:44 don't necessarily know Python very well.
05:47 So Brian is a JavaScript guy.
05:49 I'm a .NET guy.
05:50 But we're both, I like to call it Pi curious.
05:52 You know what I mean?
05:53 Like we're Python curious.
05:54 And, you know, we definitely want to show people like the different perspectives of learning
05:59 like new languages.
05:59 Yeah.
06:00 It's super interesting.
06:01 And it's really low key.
06:02 It's like you said, it's this Twitch sort of exploration style of code, not polished presentation
06:08 style.
06:09 So you just guys sit down, take feedback from the audiences and go with it.
06:13 Yeah.
06:13 I love the show because I'm never prepared.
06:15 Like I kind of just show up and talk about stuff and people love it.
06:19 And it's great.
06:21 I don't have to do notes or anything like that.
06:23 We just kind of be like, hey, what do we want to learn about today?
06:25 Right.
06:25 Well, let's go ahead and do it.
06:26 Yeah.
06:26 Fantastic.
06:27 All right.
06:28 Well, given how many of us there are, let's go ahead and just jump in and we're going to
06:32 do our year in review.
06:33 And so I've written a small piece of Python software here in the REPL.
06:36 It's very advanced.
06:37 It's at least four lines of code.
06:39 I got to tell you.
06:39 And what it's going to do is going to pick one of you and then we're going to have you
06:42 talk about what you felt was the most significant or impactful thing that you saw
06:47 happening in the Python space.
06:49 So round one, Cecil, you're on screen.
06:52 It pulled you up.
06:53 Go for it.
06:54 I got lucky.
06:54 Okay.
06:55 So the most exciting thing that I think happened in the world of Python and one that I have
07:01 a little bit of a close relationship to is the fact that Guido van Rossum joined Microsoft
07:06 just a couple of weeks ago.
07:08 So I didn't mention this before, but I do work at Microsoft as a developer advocate.
07:12 And I think for me, it's been a really interesting to kind of see how the company has been embracing
07:18 open source and working with a lot of the creators and now seeing a lot of the leaders of the industry
07:24 kind of join the company.
07:25 You know what I mean?
07:26 It kind of, you know, it's a kind of, it's like a different world.
07:29 I mean, I don't know how else to explain it or talk about it.
07:32 It's been really great to have him here.
07:34 I had the opportunity actually to interview him and we did like an internal interview
07:39 just talking about like, well, what made you decide to come out of retirement?
07:42 That's awesome.
07:43 Was this on channel nine?
07:44 Is it public or is it?
07:46 No, it was internal.
07:47 It was an internal interview.
07:48 I don't know what his, his, I don't know.
07:50 I'm sure he'll do some other ones, but we, it was an internal one.
07:53 Did you make him whiteboard?
07:54 No, we didn't do him any whiteboarding.
07:56 We did ask him what some of his favorite shows were.
07:58 So that was, that was pretty interesting.
07:59 We asked him like the Star Trek versus Star Wars conversation too.
08:03 I couldn't, I couldn't handle that pressure.
08:05 It's hard, man.
08:06 Tough crowd.
08:07 Tough crowd.
08:08 I think it's definitely amazing to be able to see folks from the industry, like kind of
08:12 embracing like these different companies and us really supporting open source in a very
08:17 like authentic way.
08:19 Yeah.
08:19 It's such a big change.
08:20 And Reuben, you were just talking before we started streaming, I think about, you know,
08:24 10 years ago, how this was really different.
08:26 Oh yeah.
08:27 I mean like even more, but yeah, even 10 years ago, the notion that Microsoft would be so
08:31 involved in the open source space and specifically the Python space was basically unthinkable.
08:36 I mean, I think it was Steve Ballmer who said that, you know, Microsoft, not Microsoft,
08:40 like the Linux and open source were a cancer on the industry and they were definitely seen, you know,
08:45 Microsoft was seen as an enemy of the open source world.
08:49 And it's been truly amazing to see them just embrace it.
08:51 I mean, you see the booth at Python, you see the VS Code investment.
08:54 It's very, very impressive.
08:56 And it demonstrates, and he says, we'll say this earlier, like how much leadership at the
09:00 top really can change the direction and the attitude of a company.
09:03 And that filters through to even the lower level people and the decisions made there.
09:07 Yeah.
09:08 That's a lot of hard work, right?
09:09 Because if you think about it, we've had different leadership for a very long time.
09:13 And so for some of us, some of this change that people are still recognizing, I mean, we've been
09:18 doing it for a very long time.
09:19 You know what I mean?
09:20 Like we didn't just in 2020 decide, oh, hey, let's adopt and support open source.
09:24 It's been one of those things that have been building, you know, very much over time.
09:28 But, you know, the fact of the matter is like you still have those old stigmas that we still
09:32 have to shake.
09:33 And, you know, we still have a lot of folks that we have to help convince that we're not
09:37 the death star and we won't, you know, destroy the world kind of thing.
09:42 But I think it's a good responsibility to take on because there's also, you know, there's
09:46 a lot to fuck up.
09:47 And if you commit to like doing something like, you know, GitHub acquisition and say, okay,
09:51 we're doing that and we're running it, you know, we're good sign forward because every
09:55 misstep can have like, you know, a really big impact.
09:59 You know, if Microsoft starts doing bad things again, people are not going to be, you know,
10:02 very forgiving at all.
10:03 So I think that was the most sensitive one of them all is the GitHub acquisition because
10:08 what they do to Azure is kind of their story.
10:10 What they do to Windows is their story.
10:12 But what they do to GitHub, that's everyone's story.
10:14 And all of a sudden, that was a big deal.
10:16 And on top of that, you have the ability to give GitHub a little bit more power in the space.
10:22 Like, I mean, we've all been kind of watching what's happening with like YouTube DL and stuff
10:26 like that.
10:27 And just seeing the support, it's not just GitHub anymore.
10:31 Now it's like, okay, what does one of the wealthiest companies in the world, you know, say
10:37 about this particular position that YouTubers have a problem with that people in tech,
10:42 have a problem with like a lot of abusive behavior.
10:45 And on top of that, you're providing support for things like NPM.
10:48 It's one of those questions.
10:50 We all want to contribute to open source, but none of us have the financial ability to contribute
10:55 like a company like Microsoft can.
10:58 So I'm not just saying we're going to be a part of it, but saying, no, we're really going
11:02 to be a part of it is like a huge deal.
11:04 Yeah.
11:04 The million dollar defense fund that they just announced is a big deal.
11:07 Yeah, for sure.
11:08 And when you think about GitHub, right?
11:10 Like you think about like developer culture, that's what GitHub kind of represents to me
11:15 is the new, you know, the future of developer culture.
11:18 Like how do we collaborate?
11:20 How do we work with each other?
11:21 How do we share not just source code, but like experiences and knowledge, right?
11:25 Through like something that we can all connect together with.
11:27 That's code, right?
11:28 And then kind of circling it back around to Vita, being able to, again, see these leaders
11:34 of these really large open source projects put their faith in the company and even considering
11:39 what the past of the company was to what it is today.
11:42 I think hopefully like the rest of the open source world would start to realize that we
11:46 are serious about being good open source citizens and supporting the culture and the community.
11:51 I mean, me personally, I'm just really excited to see what he's going to do, what he's going
11:54 to work on.
11:55 The future is bright, man.
11:56 Yeah, absolutely.
11:57 I think someone on Twitter had said, so now we actually hire folks that contributes
12:03 to, you know, obviously C# and F sharp and the .NET stuff, but also folks that contribute
12:08 to Java, Rust, C++, and obviously Python, right?
12:12 So we have a whole host of language folks underneath the umbrella of the company.
12:16 And so now being able to have that space of collaboration, like underneath the umbrella
12:20 of one company, I think is going to be really interesting to see what the next couple of years
12:24 looks like.
12:25 Yeah.
12:25 You're going to have to come back in six months and give us an update on all the Python
12:28 changes you see.
12:29 I'll give you the six month update on it.
12:30 This episode is brought to you by Linode.
12:34 Simplify your infrastructure and cut your cloud bills in half with Linode's Linux virtual machines.
12:39 Develop, deploy, and scale your modern applications faster and easier.
12:43 Whether you're developing a personal project or managing larger workloads, you deserve simple,
12:47 affordable, and accessible cloud computing solutions.
12:50 As listeners of Python Bytes, you'll get $100 free credit.
12:55 You can find all the details at pythonbytes.fm/Linode.
12:58 Linode has data centers all around the world with the same simple and consistent pricing,
13:03 regardless of location.
13:05 Choose the data center that's nearest to you and your users.
13:08 You'll receive 24-7, 365 human support with no tiers or handoffs, regardless of your plan size.
13:15 You can choose shared or dedicated compute instances, or you can use your $100 in credit on the S3 compatible object storage,
13:22 managed Kubernetes clusters, and more.
13:25 If it runs on Linux, it runs on Linode.
13:28 Visit pythonbytes.fm/Linode and click that create free account button to get started.
13:34 All right, I'm going to run the chooser.
13:36 Hall, it has chosen you.
13:38 Not sure about your chooser algorithm here.
13:40 There doesn't seem to be...
13:41 Random dot choice.
13:44 I'm telling you.
13:46 This time, it's not a good time to talk about election strategies, seeing as how it chose you first.
13:52 It could be flawed.
13:53 We're reviewing it.
13:55 Are you changing the random seat on every...
13:57 Exactly.
13:58 Exactly.
14:00 Yeah, I should be.
14:00 My topic is things change, nothing changes.
14:04 And I think I'm maybe stealing someone else's topic.
14:07 So I appreciate your random algorithm choosing me first.
14:10 And it's kind of along the line, I'm kind of interested in open source communities over the years and decades
14:14 and why one works, why one doesn't.
14:17 In particular, a lot of open source projects that get successful kind of founder when the founder leaves.
14:23 And over the last couple of years, you've seen Guido transition out, stepping down as BDFL.
14:29 And kind of a new language governance model that he didn't even decide on.
14:33 He let it emerge.
14:34 And then new release managers, new PSF directors, all happening this year.
14:39 A pandemic, which kind of destroyed the big fundraiser.
14:43 An organizing event called PyCon.
14:45 Python 2.7, end of life, which I guess a lot of us thought would never effing happen.
14:51 And it effing happened.
14:53 And through all of this change for a project that was like reaching mega escape velocity and popularity, nothing changed.
15:02 Everyone's like, who cares?
15:03 Python just kept on doing its business.
15:05 Releases kept cranking out.
15:07 Peps kept cranking out.
15:09 Elections.
15:10 Well, Python elections kept cranking out.
15:12 Michael and Brian kept cranking out podcasts.
15:15 Hallelujah.
15:16 Something good happened in 2020.
15:18 And so it's interesting to me.
15:21 Healthy projects are those with kind of a healthy bench, kind of a middle management.
15:24 Python has a hell of a middle management now.
15:27 It's awesome.
15:27 And it's like middle management in every vector now.
15:31 It's got language leadership, middle management, foundation leadership, middle management, conferences.
15:37 All the regional conferences are kicking ass, even online.
15:40 So it's really good for me to see kind of a balance between some of the old heroes like Brett Cannon, who gave this awesome keynote two or three or four years ago at PyCon about open source.
15:51 And then some of the new heroes like Marlene Mangami.
15:54 When I give the Python 1994 talk, sometimes I give it with Barry.
15:57 And it's like, well, did you ever know back then that it was good?
16:01 Hell no, we didn't know.
16:02 And so seeing all of this happen, seeing generation after generation come in, do their thing, raise the next generation is pretty cool to see.
16:10 Yeah, it's fantastic.
16:11 And I know there was a lot of uncertainty when Guido stepped down about, oh my gosh, what's going to happen.
16:17 But it's kind of been a non-issue, which is good.
16:19 Non-issue in a good way.
16:21 Yeah, I think it's really nice to also have some stability, even especially nowadays, that's quite rare.
16:28 And just to see stuff just works, nothing goes wrong, no drama, nothing terrible, just drama is almost boring.
16:36 Yeah, boring is good these days.
16:37 One of the things that really surprises me, Paul, as you mentioned the escape velocity,
16:42 what's weird to me is how Python went like 20 years on medium, like simmer popularity,
16:48 and then it hit the afterburners and took off, right?
16:51 It seems just, I think there's going to be some interesting studies done about why or how did a language that had kind of been around for 20 years,
16:58 all of a sudden really dramatically improve in popularity.
17:01 And I have some ideas, but I just think that that's an interesting aspect of what you're talking about here.
17:05 Yeah, it's also the whole aspect of the previous like Microsoft and Java and sort of, I guess, big money behind those sorts of languages in like the early 2000s, pushing them.
17:17 And then I think community and to the point of like developer gave developers what they wanted rather than maybe say enterprise-y languages.
17:27 And then I think there's a whole confluence of other things that happened as well.
17:32 But it is kind of crazy, right?
17:34 That like one of the top, if not the top languages right now, they're almost 30 years old.
17:40 And it's got issues.
17:41 It's got warts and whatnot, but it's a thriving language.
17:45 And, you know, without significant big companies behind it, right?
17:49 That it's competing with companies that have thrown millions of dollars into development of these things.
17:54 Yeah, absolutely.
17:55 And Matt and Ines, you two are on the data science side.
17:58 And I think the data science and computational folks are the ones that poured the gas on the fire and really made it take off.
18:05 And that's not where the growth necessarily completely is, but I think that gave it a serious kick.
18:09 Yeah.
18:09 No, actually, because I get asked about this a lot.
18:12 Like, oh, what do you think made Python the language for machine learning data science?
18:16 And my theory is actually that, A, Python, of course, was lucky that it was in the right place at the right time.
18:21 But I think actually it won because it's a general purpose language.
18:24 People can come from other fields of Python into machine learning data science, for example.
18:29 Like, what did people do before?
18:31 If you look at kind of, you know, these surveys of what they use Python for before, it's a lot of web stuff.
18:35 You can build kind of anything in Python.
18:38 And I think that's what makes it so appealing and much more appealing than, let's say, like an AI language.
18:43 And that's also, in my opinion, why a lot of these attempts at making an AI language haven't taken off.
18:48 And people are like, no, Python is great.
18:49 It's fast enough.
18:51 It's usable enough.
18:52 But I think the general purpose-ness really is what kind of got it over the edge there.
18:57 A lot of people that I'm teaching or training are people who don't want to be programmers.
19:03 They want to use Python as a tool.
19:04 It's like Excel to them.
19:06 They don't want to be programmers.
19:07 And so something that they can pick up and it just sort of works and they can go to Stack Overflow and copy something.
19:14 And as long as they get the indentation right, it sort of works as long as they're using the right version or whatever.
19:20 There's no compiling.
19:21 There's no linking.
19:22 Yeah.
19:22 Weirdness.
19:23 And then you have things like Google Colab or whatever, where you have an environment, it's all set up, and you can just sort of go, right?
19:30 And so that is really empowering for people who don't want to be programmers but view Python as a tool, a necessary tool that they need to leverage.
19:39 And in addition, there's over a quarter of a million packages on PyPI, right?
19:44 And that's like literally standing on the shoulders of giants.
19:48 You can go there and pick out something that you want to do, and you're a pipa install away from it.
19:55 And that's super powerful, right?
19:57 You don't have to set up a huge environment.
19:59 And yeah, it just really simplifies life for a lot of these people who don't want to be programmers but want to leverage these really cool.
20:07 But at the same time, you do have very strong support for C extensions.
20:12 So if you're looking at the top packages people download from PyPI, most of them are written in C, Siphon, whatever.
20:20 That's what makes them so powerful.
20:22 So we have that while also being able to provide a pretty good developer experience.
20:26 Yeah, absolutely.
20:27 I think it was Seymour Papper who talked about a good language having, he was talking about a logo, but it's even more appropriate for Python, having low floors and high ceiling.
20:36 That's really easy to get in and do simple stuff.
20:39 But when you want to do complex stuff, you're not limited.
20:41 And so just yesterday, I was doing a workshop with people, and someone who had just started with Python, I said,
20:47 Oh, but look what we can do if we sort of extend it several layers.
20:51 And he was amazed how complex you can get and how sophisticated you can get just in a few lines of code.
20:57 It's really a testament to the elegance of the design of the language, I think.
21:00 Yeah.
21:01 Andre Vlasowski in chat makes a good point that many folks say Python is their second favorite language.
21:07 And there's something to be said for that.
21:10 Derek, sorry.
21:11 Should be there first.
21:12 I'm with you.
21:13 I'm with you.
21:14 Well, to that point, I mean, it's also been said that Python is the second best language for doing things right.
21:19 So you might have a language that's better.
21:20 Yeah, that's actually his quote.
21:22 I got it wrong.
21:22 Data science.
21:23 Or you might have a language that's better for web apps.
21:25 You might have a language that's better for like system admin.
21:29 But there's probably not a language that's going to like get you all three of those, right?
21:33 And Python is sort of that Venn diagram that gets you in the middle and is good enough to do a lot of what you want to do.
21:40 Absolutely.
21:41 Random or not choice?
21:42 Chooses Brian Okken.
21:43 Well, hey.
21:44 Cool.
21:44 Let me pull up my notes.
21:46 It was interesting.
21:46 We were talking about Microsoft.
21:47 And I didn't choose this, but I'm going to mention it anyway.
21:52 Tons of projects switched over to GitHub Actions in 2020.
21:55 And I mean, because it just kind of hit the area right like at the end of 2019.
22:01 So I saw a lot of projects migrating to GitHub Actions.
22:05 Anyway, I wanted to talk about packaging, which is sort of related.
22:08 There's a couple things.
22:10 I know I was supposed to pick one.
22:11 The exciting thing happened today.
22:12 pip 20.3 was released and the dependency resolver is now the default.
22:18 The dependency resolver is already angry at me for trying to deploy some Dependabot changes.
22:24 I'm excited about this and it's bit me already too.
22:27 I had requirements.txt files that have broken dependencies.
22:31 So I have to go look at those and see, well, which, you know, I have to pay attention to it.
22:35 So there's a little bit of pain for some people, but it was such a long struggle.
22:40 And I look back and the request for a dependency resolver came in 2013.
22:46 So seven years later, but something magical happened in 2019.
22:50 And that was some money from Mozilla came through and they threw some of that money at the dependency resolver.
22:56 That was pretty cool.
22:57 Yeah.
22:57 That's a big deal.
22:58 That money was, there's been a couple of these experiences where money was given to Python specifically to hire a team to improve something.
23:07 PyPI, the rewrite of pypi.org was one.
23:09 And then this is another.
23:10 Yeah.
23:11 And they rolled it out in several versions.
23:12 So we had our version early, early in the year.
23:15 And then around July, we had another version that had a different flag that you could try it out with to try to get some of the early adopters to try it out to make sure it's working.
23:22 And then today it's rolled out for good.
23:25 And I'm pretty excited about it.
23:26 I kind of want to tie this in with the packaging.
23:29 I've seen a lot of progress on and a lot of adoption of the pyproject.toml kind of taking over more packages and more uses.
23:37 So we saw Flit used to have its own any file now only uses pyproject.toml.
23:43 There's been additions to the metadata definition that hopefully will take hold.
23:50 And even pytest now, you can throw your configuration in a pyproject.toml.
23:55 And I've seen more and more projects getting pressure from their users to say, I don't want another any file.
24:01 I want to put my settings in the pyproject.toml.
24:04 So that's a good thing.
24:05 Yeah, absolutely.
24:06 You know, a couple of things on that.
24:08 You talked about two things when you talked about packaging and you talked about GitHub.
24:11 I mean, the fact that now you can actually do some package work within GitHub itself.
24:16 I built a lot of small little tools, not things that I would want to go on PyPI.
24:22 I know we don't need to clutter that up anymore with my garbage.
24:24 But it's great when I can just say like, hey, here's a link.
24:29 And if you're really concerned on how to add it, you can just pip install but point to this GitHub, you know, and that works.
24:36 Yeah.
24:37 And also the stuff about finding security vulnerabilities automatically and doing PRs for you that GitHub does against like your various package definitions.
24:46 I think that's great as well.
24:47 Hey, has anybody ever put a JavaScript package on the GitHub package.json?
24:53 Probably, but not me.
24:55 I have.
24:57 You know, this is a Python podcast, right?
24:59 No worse.
25:00 It's Gatsby.
25:01 So I basically put 500,000 JavaScript packages into my repo.
25:06 Yeah.
25:07 And I'm not.
25:09 That is something I appreciate about Python a lot that like I asked you, I never thought I'd say this, but like I do prefer also that.
25:15 I can't resolve the Dependabot security mega warnings fast enough.
25:20 It's just incredible.
25:22 I know.
25:23 And I just turn them off, right?
25:24 Like, you just don't.
25:25 Yeah.
25:26 That totally fixes it.
25:27 You're right.
25:28 That is one way to do it.
25:30 Yes.
25:30 It's like I've always said that's a problem with writing tests, right?
25:34 Like when I started programming, I was all like kind of hate writing these tests because they keep pointing out shit that's kind of wrong.
25:39 And then I have to fix that.
25:40 But I don't have tests.
25:41 It all works fine.
25:43 And then I'm happy.
25:43 Same with, I don't know, TypeScript.
25:45 Exactly.
25:45 I actually even type hints to some.
25:47 Fuck, yeah, I know that's kind of wrong.
25:49 So now I actually have to fix it.
25:51 So, you know, just don't.
25:53 So we should not let you speak it on high school.
25:54 It's the see no evil, hear no evil.
25:57 I do think that the Dependabot stuff, there is something about turning it off.
26:03 It drives me crazy.
26:04 I really value it.
26:05 But at the same time, the reason I had this conflict with the dependency resolver is it told me I should give me a PR to upgrade one thing, but not one of the dependencies for which
26:15 the newer version was required.
26:16 It would break the resolver.
26:18 It's just like, ah, what is this thing doing?
26:19 All right.
26:20 Very good.
26:21 Very good, Brian.
26:21 The chooser.
26:22 Sorry, you need a batch, batch dependency resolver.
26:26 Yes.
26:26 One that resolves everything at once and then makes sure you've got a working state at the end.
26:31 Well, the thing is, the pimp is fine.
26:33 It was right.
26:34 It's that Dependabot, if you have 100, I probably had 20 dependencies in this thing.
26:39 It gives you one PR for each line.
26:42 Sometimes it lags a day on the other one.
26:44 And if it gets it out of order, then the resolver gets it.
26:47 Anyway, long story.
26:48 Frustrating.
26:49 I mean, to be fair, speaking of dependency resolving from the perspective of a library developer, it is hard.
26:55 And it's, you know, you do want to use versioning properly.
26:57 And I do feel like there's this eternal conflict between how do we manage dependencies properly for users and how can we make sure that we can define how our packages depend on each other in a way that's reasonable.
27:10 Because not, you know, use semantic versioning.
27:12 Not everything is a major release.
27:14 Not everything is a breaking release.
27:15 But stuff just depends on each other.
27:17 And you don't want to lock people in.
27:18 There's always this, you know, the idea is you should be able to pick up your project a year later with its requirements and it should run.
27:25 And that's really, really, really hard.
27:27 Yeah.
27:28 And if it gets wrong, then you probably get a lot of email or a lot of GitHub issues.
27:31 Hey, Brian, on your topic of PyProject Toml, what's the latest, greatest on editable installs?
27:37 I don't think it's completely working for all the same.
27:40 So I'd like to be able to say pip install dash E.
27:43 Is it dash E?
27:44 And just a project.
27:45 You can say pip install just a directory no matter what kind of packager it has.
27:52 So that works now.
27:53 So you can, if you, even if you use flit or something, you can't do dash E.
27:57 But flit itself, for instance, has its own editable install thing.
28:01 And I don't know what poetry does.
28:03 I don't use poetry.
28:04 So it's a different command.
28:06 I'm annoyed that it doesn't just convert it.
28:08 I wish it would plug it in.
28:09 But I think that'll be coming in maybe in 2020 or 20, probably not this year.
28:14 Maybe next year.
28:15 Hopefully.
28:16 Yep.
28:16 Badwolf says in the chats, what is the quick solution for getting pip version updated?
28:22 The first thing you created a virtual environment.
28:23 This is another thing that drives me crazy about pip.
28:25 And if that could get changed, I would love it.
28:27 When you create a new virtual environment, basically for about a week, you have the latest pip.
28:32 And then afterwards, soon as you pip install something, it says, warning, your pip is out
28:36 of date.
28:37 As soon as you create a virtual environment.
28:38 It's like, well, why didn't you just update it?
28:39 I want, if you're going to tell me it's wrong, just fix it.
28:42 You can use virtual environment.
28:43 Instead of VENV, use virtual environment.
28:45 Because then you can update your pip and you can update the global one and install it in
28:50 all your environments.
28:50 Interesting.
28:51 Yeah.
28:52 I just wrote an alias that will create the virtual environment, upgrade pip and set up
28:56 tools, and then activate it.
28:57 Other way around.
28:58 Activate it, then upgrade.
28:59 Yeah.
28:59 Yeah.
29:00 It's funny.
29:00 I have a shortcut like that too.
29:02 Yeah.
29:02 Awesome.
29:03 And then you can also have it install everything you need, you know, in the same command,
29:06 automatically create once, which I shared my script somewhere, I think on Twitter, if
29:11 anyone's interested.
29:12 Nice.
29:12 Yeah.
29:12 Mine's just V and V.
29:13 I just type V and V and magic happens.
29:15 I don't think of it anymore.
29:16 Well, when I finally switched to virtual LENV, it's like, I make so many virtual environments.
29:21 It's so much faster.
29:22 And just that, even just a few seconds, several times a day, it's worth it for me.
29:27 So yeah.
29:28 Awesome.
29:29 All right.
29:30 I've chosen next and there's a dependency in the chooser.
29:33 So it's worked correctly.
29:34 So it's chosen me actually to talk about the next thing.
29:37 And Paul touched on this, but I think this is a really important one.
29:40 Like this is the year that Python 2 actually went away.
29:45 And it's, I just spent so long having to justify why Python 3 is the right thing or more often
29:53 teaching people, no, no, no, you can't type Python.
29:55 Please don't do that.
29:56 Unless you're on Windows and you have to do that.
29:58 But if you're not on Windows, then you better not do that.
30:00 So you got to, you know, it's just like this drag.
30:02 It always felt like things like Django or Flask and whatnot were being held back.
30:07 All these libraries were being held back by Python 2 support.
30:11 And last year they started dropping it.
30:13 And then Python 2 itself actually went away.
30:15 Brian and I tried to create the right nomenclature around this, I guess.
30:19 It's calling it legacy Python and modern Python rather than 2 and 3.
30:23 And that was, that was fun.
30:24 People started to quote it and use that terminology, which was kind of cool.
30:27 I don't know how well it worked, but it's really nice that Python 2 is finally officially
30:32 gone.
30:32 And I thought there'd be a bunch of people would freak out for Python and start creating
30:37 like alternate old versions.
30:39 And I haven't, besides some like support, commercial support stuff, I've really seen that happening.
30:43 So it's, it's pretty interesting, I think.
30:45 Yeah.
30:45 I think we should have brought like horns and stuff and like, you know, maybe just, just.
30:51 Some of those little pop, like bottle looking stuff on New Year's.
30:55 Absolutely.
30:56 Yeah.
30:56 I mean, we really didn't get the party we were hoping for, right?
30:58 Like PyCon was supposed to be this big send off for Python 2, but no, there was not so
31:04 much of a PyCon.
31:05 Not really.
31:05 I mean, there's online, but it wasn't the same.
31:07 Now we just got to wait until we have all of the articles about the companies that finally
31:12 decided to switch and the steps that they took that they avoided for the last decade to,
31:17 to make this a reality.
31:19 Yeah.
31:20 I mean, one of my biggest corporate training clients, they have been using Python 2 for years
31:24 and years and they do all sorts of testing of hardware using windows.
31:30 And so with all sorts of custom C extensions.
31:32 So I've been saying to them for years, every time I do training, look, you should really
31:36 think about Python 3 and you should realize you should move in that direction.
31:38 And their attitude was basically, no, no, no.
31:41 We've got so much invested in what we've done.
31:43 We're not really going to upgrade.
31:45 And finally, about, I guess, a year ago, they realized, huh, we're going to be stuck on
31:49 our own maintaining everything, including all these packages of PyPI.
31:53 Maybe it's time to start talking about it.
31:55 And so I'm actually doing some training for them now.
31:58 And I asked a group, should we do Python 2 or should we do Python 3?
32:01 And the majority actually said it's okay to use 3 because our group has switched.
32:05 So if they are moving, it's clear that even sort of the draggiest of the draggiest companies
32:11 are doing it.
32:12 Yeah, I was just going to echo what Ruben said that when you have success and you get
32:17 enterprises using your stuff and enterprises are slow to move.
32:22 And I don't want to criticize Python 3 too much, but I think if they would have put F-strings
32:27 in 3.0, then they wouldn't have had this problem.
32:29 But because they waited to put F-strings in, then they had people dragging their feet.
32:33 So weird how that dragged.
32:34 That was one of the most popular features, for sure.
32:36 So you're saying the walrus operator was what finally did it?
32:40 I'm not going to go there.
32:44 You know, I was not super excited about the walrus operator.
32:46 I find myself using it all the time.
32:48 I like it.
32:48 It's neat.
32:49 Oh, it's cool.
32:50 I think it definitely solves a problem.
32:51 I just, wait, that's 3.8, right?
32:53 The walrus?
32:53 I believe so.
32:54 Yeah.
32:55 Yeah.
32:56 I'm still, I mean, I feel like I'm now back at like, okay, we finally dropped support
32:59 for two from all of our libraries that we're developing.
33:01 And now we're on 3.6 because.
33:03 No, no, no.
33:04 The 3.9 is current.
33:06 3.8 is now the new legacy Python.
33:08 Ines, how was it for you?
33:12 Like as a library developer?
33:14 Yeah.
33:15 I mean, I feel like I only really got to use Python 3 this year.
33:19 I mean, of course I've been using it privately for much longer, but I would say in mid this
33:24 year, I was finally like, cool.
33:25 I just use type hints.
33:26 I use f-strings across all of our projects because before our dependencies had to support
33:30 people on two and our old version of space, they had to support people who wanted to use
33:34 two.
33:34 So that's, that kind of becomes the baseline.
33:36 And now we've moved that up to 3.6.
33:38 And so on to 3.6 is dead.
33:41 There's still always new features that, you know, we can't just, you know, ship.
33:44 Yeah.
33:45 But that step from 2 to 3.6 is going to be way bigger than 3.6 to 7, right?
33:51 That's a very small step to 3.6 to 3.7 or 3.7 to 3.8.
33:54 So you've, you've done the big step.
33:56 Yeah.
33:57 Yeah.
33:57 And some of the new features, it's like, yeah, whatever I can, you know, live without writing
34:01 those in my code base and people can still use them in their code bases.
34:04 But yeah, all the new versions we're going to publish, like Spacey 3, that's coming soon.
34:08 We'll use Python 3 in the code base and we'll only work with Python 3.
34:13 We want to distribute wheels for Python 2, which we might have not even done for a while because
34:18 it's really, really a pain for some of our more abstract and complex dependencies that we're
34:22 also building.
34:23 Yeah, cool.
34:24 So far, people haven't really complained.
34:25 Like I was, I was expecting people to complain a bit more, but like, no.
34:27 Well, if you look at the PSF JetBrains survey, the data science folks, that side of the
34:33 house have definitely moved to Python 3 quicker and bigger than the web team.
34:37 I'm actually surprised how quickly people move up.
34:39 Like, you know, I don't know, even after 3.9 came out, we've had people requesting like,
34:43 oh my God, why does your, you know, annotation tool not work on, you know, 3.9?
34:47 Or why does this not work?
34:48 And it's like, nothing works on 3.9.
34:50 Or it's like, LCI doesn't do 3.9 yet.
34:53 Like I can't build anything.
34:55 None of our other packages run.
34:57 Like, sorry.
34:58 I felt like a big person developer for like the first time ever when I actually got,
35:03 my first issue with running the latest and greatest Python.
35:07 It was because I was running GCP and I kept running into an error, running into an error.
35:10 And I was like, you know what?
35:11 It used to work.
35:13 Let me just try it on 3.8.5.
35:14 And then sure enough, it worked perfectly.
35:16 And I was like, I've done it.
35:17 I've reached the new achievement.
35:20 Nice.
35:21 Yeah.
35:21 I've taken down the Talk Python training website by shipping the walrus operator accidentally.
35:25 At the time, Ubuntu didn't support it.
35:28 A quick question or a comment from Zach in the comments about when, you know, we can actually
35:34 say legacy Python's gone when the OS vendor stops supporting it.
35:36 I think Python 2 is no longer shipping with the new macOS and Canonical is starting to make
35:42 Python 3.8 the default.
35:43 So I think we're getting there.
35:45 I thought they were removing Python in general from macOS and just making you install it yourself.
35:52 I think there might be some internal system thing.
35:54 I saw people talking about the system Python 3.8, even though I agree I heard the same thing
35:58 you said.
35:58 But I don't have a fresh install.
36:00 I think it's not actually such a bad idea.
36:02 Like I think, you know, for most things you do, you have to install some extra stuff anyway.
36:06 So making it a more explicit install from a user's perspective, I think isn't even so terrible.
36:11 Yeah.
36:12 Because otherwise, you know, if you just type in Python, you just run into all kinds of potential
36:16 issues anyway.
36:17 Yeah.
36:18 Especially when it's super out of date.
36:19 All right.
36:20 Yeah, I definitely end up like telling people in my courses, oh, you're using a Mac?
36:24 Yeah.
36:24 Ignore the Python that's installed.
36:26 I know this is a Python course.
36:27 Ignore the ones that's installed.
36:29 And here are ways that you can install it on your own.
36:31 So it'll be up to date.
36:32 And here's how you can make sure it doesn't conflict with what's already installed.
36:35 So maybe removing it all together is not such a terrible thing.
36:38 Yeah, for sure.
36:39 Homebrew, homebrew.
36:40 All right.
36:41 Ines, the voting system has chosen you next.
36:43 Unmute myself and look at my notes.
36:45 Yeah.
36:45 So I think I've already mentioned the topic I was going to talk about, about
36:50 five times so far.
36:51 But yeah, I think in 2020, we really saw the ecosystem around type hints, static type checking,
36:59 types in general mature and really be widely adopted.
37:02 And I do think a part of that is the more widespread adoption of Python 3.
37:06 Because before that, to be fair, you could use type hints before Python 3 just for completeness.
37:12 But like, that's not what people did.
37:13 And it looked very, very different.
37:15 So yeah, now and actually, even I couldn't really imagine writing code without type hints anymore.
37:20 Like if I write something and I'm not adding any types, it feels kind of naked and it feels kind of wrong.
37:25 And I actually feel like, oh my God, I might be missing some issues here.
37:29 Maybe I'm not catching some bugs.
37:31 So yeah, which is quite surprising.
37:32 But it says something considering I only just recently was able to really embrace all the new Python 3 stuff.
37:39 Yeah, that's a pretty quick transition.
37:40 Find it, yeah.
37:41 I depend on this thing now that like previously you had to stay away from.
37:45 Yeah.
37:46 And I have static type checking enabled in Visual Studio Code.
37:50 It underlines things if you pass in the wrong types.
37:54 It gives you all these nice like autocomplete prompts or previews if you want to.
37:58 That's also something I've gotten really, really used to over a really short period of time.
38:01 Like, I don't know.
38:02 What about you, everyone?
38:04 Like, do you use type hints?
38:05 Like, can we have like an opinion, Paul?
38:07 Like, just raise the hand and then we summarize it for people who just...
38:09 End of hand race.
38:11 Everybody.
38:11 I'm slowly starting to use them more and more.
38:17 I see the advantages.
38:19 And in part, as I mentioned before, we started recording, like, because my students are encouraging me to use it more and more.
38:24 Because they want it.
38:24 Because they come from languages where there's no such thing as optional type hints.
38:28 It's, you must do this or the program does not run.
38:30 So, what do you know?
38:31 They can actually be useful.
38:33 Yeah, I think that's one of the biggest benefits that I like about the type hinting system is that it's optional.
38:38 So, you could choose to use it.
38:39 And then, if you don't need it, then we could just take it out.
38:42 Because for me, like, I believe in lazy, being a lazy developer.
38:45 And stuff like type hints just make certain things a little bit more discoverable.
38:49 Right?
38:50 And kind of like what we were saying before.
38:52 Like, it just improves your tooling to be able to discover more of your code for you.
38:57 I like to use it.
38:58 I like to use it for APIs, especially for package interfaces.
39:01 So, that people using a package can use the editor tools and stuff like that for the hints.
39:08 And also, just wherever it makes sense.
39:10 I mean, if it looks like it actually detracts from readability, then I take it out.
39:16 Readability is above all for me.
39:18 So, if it's usable and readable, it helps.
39:20 I feel like they're working on that.
39:21 I just wouldn't advocate.
39:22 Oh, sorry.
39:22 Any, like, I don't know.
39:23 If you have a function that takes several arguments and then returns, like, a callback, that gives you this kind of typing.
39:29 I wouldn't advocate for that necessarily.
39:30 But, yeah.
39:31 And I feel like they're working on some of that confusion as well and some of that, like, clutter and blood.
39:37 I mean, that was, I talk about that 3.9 story.
39:39 It was because I was tired of typing, typing.list or typing.dict.
39:44 And it was just like, oh, you mean I can just do this now?
39:46 Like, and then sure enough, you know, stuff crashes.
39:49 And it's like, well, guess not.
39:50 Maybe later.
39:51 But it's great that for people who are looking at Python as a tool that they're using, not the language that they're writing on a day-to-day, but just flat out the tool that they're using, they don't know what we're talking about half the time.
40:08 But they can kind of look at something and go, STR, hmm.
40:12 Someone mentioned a string that one time.
40:14 Maybe that's what that is.
40:15 You know, it's a lot easier than just looking at the code and trying to figure it out.
40:19 Yeah.
40:19 And speaking of tools, I think type-ins, they're not only that syntax feature.
40:23 They've really enabled this whole new ecosystem of tools that use type-ins to accomplish something else or in a creative way.
40:32 And I think many of them have been covered on this podcast previously.
40:35 For example, there's Pydantic, which uses type-ins in actually one of my favorite creative ways for data validation, settings management.
40:41 It's actually a library we've adopted across a lot of our projects to just quickly, you know, you define this interface.
40:46 Here's what I expect.
40:47 You get like, you know, kind of like JSON schema just with type-ins.
40:51 Pydantic is so wonderful.
40:52 Yeah, you're right.
40:53 It's really nice.
40:54 It's really nice.
40:55 Yeah, I would say it's one of my favorite recent discoveries in terms of Python developer tools.
40:59 And then, of course, there's FastAPI and Typer developed by my colleague, Sebastian, which probably has been discussed a lot on this and related podcast.
41:08 Yeah, he was on the show not long ago, like 10 shows ago or so.
41:11 And yeah, that's a fantastic framework, too.
41:13 Yeah, so that's, I think it's also partly what really popular, popularized, great word, type-ins in as a tool for, yeah, developing applications and so on, I think.
41:28 Also actually Pydantic.
41:30 And yeah, we've also, in 2020, I think, released our machine learning library, Think, which kind of functions more like an interface layer and lets you write neural networks, combine layers written in different frameworks like PyTorch, TensorFlow.
41:44 And we've included custom types for arrays and all that stuff that passes through the network.
41:49 Because, you know, if you're doing machine learning, a lot of it is like really abstract.
41:52 You have like this multidimensional array as in like 300 dimensions.
41:57 And then that goes through and then it gets transformed and then it goes all the way back.
42:00 And at the end, you're hoping to get something out.
42:02 And there's a lot that can go wrong.
42:03 And it's not even about like, oh, how experienced are you as a programmer?
42:07 It's like that shit's just abstract.
42:09 And we can make it a bit less abstract even by just providing custom types that you can declare.
42:15 So it's easier to see what goes in, what comes out.
42:18 Do these layers fit together?
42:20 Do they not?
42:21 Because otherwise, yeah, you easily end up with these very hard to debug NumPy errors triggered by like five layers deep that tell you that you can't broadcast that shape into this other shape.
42:31 And you're like, yeah, that's going to be fun.
42:33 This doesn't help me.
42:34 I have no idea.
42:35 Yeah, I think there's also things like mypyC, which will compile stuff that has types.
42:41 And there's Cython, which will use the new Python type hints to compile to much faster code.
42:45 So there's a lot of neat things coming out of it.
42:47 Yeah.
42:47 And I think especially also for abstract stuff like machine learning, there are lots of use cases that web type hints and type-based validation is really promising because we can also take something a developer already knows, like typing your functions, typing your layers, and it will just work and do some extra stuff if you want it to.
43:03 Watching mypy evolve is really cool.
43:06 For think, we've briefly dabbled in custom mypy plugins for a bit.
43:12 We have a plugin that checks if two layers you're chaining together return the correct types.
43:18 Like if you have one layer that returns a two-dimensional array of floats and the other layer expects a two-dimensional array of integers or four dimensions, whatever, you can actually see that underlined in your editor done by mypy as you type the code.
43:31 So you can prevent a bug before you even type it and introduce it.
43:37 So that's cool.
43:37 And I think that's all very actively developing.
43:40 So I think there's so much potential for custom plugins.
43:43 Like imagine more libraries just coming with their own mypy plugins that help the developers use those libraries better.
43:49 I think, yeah, that's all super cool.
43:51 Yeah, it's early days and there's a bunch of great tools.
43:53 Cecil, let me round this out with coming back to one thing you said.
43:57 You talked about how it was optional.
43:58 The closest analogy that I think we have to this in other languages has got to be TypeScript, which is like JavaScript plus types and a little transpiling thing.
44:07 And it's all cool.
44:08 But all my interactions with TypeScript are like, oh, you haven't declared this thing right.
44:11 This thing's, it's like, it's as picky as C++ or C# or Java.
44:16 But it's, it's not as like built from the start, like the tools aren't necessarily all there to make that fit together.
44:23 So I always feel like I'm kind of stumbling over the things like 80% of the time it's helped me and 20% of the time it frustrates me.
44:30 Whereas like here you can just kind of, you can leave it off, take it or leave it if it's good, not good.
44:34 Yeah.
44:34 Yeah.
44:35 I think TypeScript definitely helped with some learnings about how developers want to interact with typing.
44:41 I think the thing with TypeScript, it is very, like there's a lot of features in there and it's very customizable.
44:46 But, you know, it's kind of like you have like a nail, right?
44:50 And it gave you a jackhammer.
44:51 You really don't need the jackhammer.
44:53 Exactly.
44:54 Maybe a little finishing hammer would be nice.
44:57 Yeah.
44:57 There's a lot of different things that you can customize.
44:59 And some people need that.
45:00 But I think for 90% of folks, I'm making up that number.
45:04 That's not a real number.
45:05 But for a lot of folks, you probably don't need a lot of those knobs to turn and options to set.
45:11 Yeah, absolutely.
45:11 There was like a two-year period with TypeScript where I'd read the roadmap.
45:15 They do a great job of running their project.
45:18 Great job.
45:19 But they put a feature in using words I didn't know from type theory.
45:23 And my answer was, oh, that's for Angular.
45:27 Oh, that's for Angular.
45:28 Oh, Angular is the only one having that problem.
45:30 There's some serious machinery.
45:33 Yeah, there is.
45:34 All right.
45:34 Final thought on this from the chat is Eric O'Shaughnessy says, I love how typing solidifies the author's intent.
45:41 Yeah.
45:41 All right.
45:42 Let's have the chooser choose again.
45:44 Jay.
45:45 All right.
45:46 So I totally didn't peanut butter on this.
45:48 But as y'all were talking, I just got some wonderful ideas.
45:52 And I immediately started thinking about just the doubling down of some of the
45:57 technologies that we've seen kind of pop up over the last couple of years, but then truly
46:02 evolve.
46:02 And one of the biggest examples of that, and I know I'm five years, daily, dollar short here,
46:07 but anything Jupyter Notebook related, it's not just for the solo data scientist anymore.
46:16 collaborative Jupyter Notebooks.
46:18 Like to me that I know people that just have dreams about that.
46:21 And they're like the best dreams ever.
46:23 And, you know, I know, Mike, you just did a podcast episode a few weeks back about that.
46:31 And we were talking about it on Python Bytes a little bit.
46:32 They're like, it's not just one option anymore.
46:35 It's, you know, there's cocalc, there's PyBinder, there's DeepNote.
46:38 Apparently I'm a DeepNote influencer and I didn't even know it.
46:41 That's awesome.
46:42 You are bringing it up again.
46:44 Again, exactly.
46:45 But not just in like Jupyter land, we have like crazy ideas.
46:50 Like what if we could do Python on the front end with Anvil?
46:54 And like now Anvil is saying like, hey, we're going to open source some of our server technology
46:59 so that you can take this technology and do it yourself.
47:02 And I think that that's just like with Type Hints, we're coming up with these ideas and
47:07 we're taking them a step further.
47:08 I think that this is what, in my opinion, has kept me in the Python ecosystem as long as it
47:14 has, is because I'm constantly learning about like brand new ways to do a thing in Python.
47:22 And I have to talk about this because I told people in my Slack channel that I would.
47:25 But like we just, you know, at Elastic, we just launched a brand new tool called Elant
47:29 and it's in beta.
47:30 And the whole idea is it's like a Pandas data frame.
47:33 But instead of storing all of your data in memory, you can store it in an Elastic search,
47:37 you know, data store.
47:38 Oh, that's an interesting idea.
47:39 So now instead of being limited to what your RAM can hold, you're limited to how much space
47:47 you got and you can run search and you can run queries on it.
47:50 You can tie it into things like, you know, scikit learn and TensorFlow and do, you know,
47:55 any type of machine learning on it.
47:56 And at the end of the day, you're doing transforms on the data as it's in the data store.
48:02 So there's no more downloading a bunch of data, working on it and trying to re-upload it.
48:06 And it's off of the backs of crazy ideas from people crazier than I am that are just like,
48:13 hey, what if we could do this?
48:14 And, you know, to me, that's all I wanted to do with Python is just make up goofy stuff
48:19 and see if it would work.
48:21 I think that's an interesting idea.
48:22 You could start using things like lots of data and things like serverless,
48:26 where you get really short execution times and not much power.
48:29 But if it's already in something like Elastic, you could do pandas against it,
48:33 like quote pandas, like the API against it without really suffering a lot of trying to
48:38 download it to your little Docker Lambda callback thing before it runs out of time to execute
48:43 and whatnot.
48:44 Yeah.
48:44 Actually, I think I've seen some people do some cool stuff with Spacey and Elastic as well,
48:48 you know, processing all the huge volumes of text, which also I think is such an interesting
48:53 part of our application of data science.
48:55 Like, you know, you want to have, you have so much text that, you know, you can't even,
48:59 nobody can read it.
49:00 You can barely store it, but you can still analyze it and process it and find something out about
49:05 it that otherwise.
49:06 So yeah, that's, that actually sounds quite cool.
49:08 I mean, the problems I was, I was having initially was just this amazing problem of like, I've got
49:14 a million lines of data that I need to do something with.
49:18 And I've got this little Mac mini here.
49:20 That's just chugging along, trying its best.
49:22 And everyone's like, well, why don't you just use the Google API?
49:24 And it was like, okay, well, I did the math.
49:26 I'm going to need $20,000.
49:27 And it's like, okay, so we can't use the Google API.
49:30 We can't solve it with that problem.
49:32 What else do we got?
49:32 And now it's like, oh, wait, you mean I can just store all this data?
49:36 Because I'm, it's only a few gigs, but then I can just hit my local server as many times
49:41 as I want.
49:41 Let, you know, search store or any type of data store that's good at retrieving the data
49:47 as I want it, as I need it, and then let it do its thing.
49:50 Like that solved a $20,000 problem.
49:53 I mean, even, even a site for the cash.
49:56 Do you want to send all your data to Google?
49:57 Probably not.
49:58 Yeah.
49:58 I mean, that's awesome.
50:00 Even if it were free.
50:03 You can also send it to Facebook while you're at it.
50:05 I don't know.
50:06 I was, I was working with police call records.
50:08 So I don't want to send that data anywhere.
50:10 I don't want to be on a watch list.
50:12 No, exactly.
50:13 And I think those are like really, a lot of these really important applications of the technology
50:17 when in the health domain, people are doing good and useful stuff, but they should not
50:21 do that stuff at that type of cost, which means sharing all of their sensitive data with
50:26 companies that will, you know, want it for some other reason.
50:29 Yeah, absolutely.
50:30 Matt, Reuven, you guys do training.
50:32 What's the Jupyter story around there?
50:34 I did a class with not Jupyter, but it was all collab based this morning.
50:38 So yeah, I use it a lot.
50:40 I think it's great for beginners.
50:41 Like I said, for a lot of people who are scientists or engineers, that's what they sort of consider
50:48 Excel.
50:49 And so a lot of them sort of want to sit in Jupyter all day.
50:53 They don't even want to like think about modules or code or even software engineering.
50:59 Right.
50:59 And so it's somewhat of a challenge for me to sort of say, okay, let's talk about some engineering
51:05 skills and some good best practices for Python projects.
51:09 And I'm like, oh, I don't want to leave Jupyter.
51:10 Right.
51:11 Can I do this all in Jupyter?
51:12 I'm like, well, you could, but you kind of don't want to per se.
51:16 But yeah, definitely cool.
51:17 I think what I'd love to see is Inez's fancy mypyChecker hooked up with pandas on Jupyter.
51:24 That would make my day because that's one of the things that I find confuses people just
51:29 with pandas having 50 ways to do things and then objects returning five different types
51:34 or methods that return five different types that like you don't get any tab completion or
51:39 any of that good stuff in Jupyter when you're doing a lot of the machine learning stuff.
51:43 Yeah. And a bunch of like grownup engineering stuff is coming to Jupyter, right? Like NBDev,
51:48 NBQA, some of these other stuff that's coming there is making it way more interesting for that
51:54 regard.
51:54 Yeah. The NBDev stuff is interesting just coming. I mean, that's sort of taking it to that sort
51:59 of literate style of programming where we're going to stay in Jupyter all day and do everything
52:03 from that. And then, you know, Netflix has their stuff where they're deploying Jupyter
52:07 notebooks to production.
52:09 Yeah. It was paper mill. Yeah.
52:10 Reuben, how about you? And then I'm going to run the chooser.
52:12 So I, yeah, I mean, I use, oh, so I use Jupyter every day for my training. I don't use slides. I
52:18 just do live coding. And I find that's a great way to show them not just sort of the answer. This
52:24 is how you code something, but this is the process you use to get to the solution because teaching
52:29 people that process is really important. And it also means I can share with them everything that
52:33 I typed during the day really, really easily. People are a little resistant to using it first,
52:37 especially experienced developers. They're like, wait, what is this thing? Why are you not using a normal
52:41 IDE? I'm actually forced myself in the last year to remember, oh yeah, we should do a few exercises
52:46 and tell them to use the IDE so they won't think that everything is done in Jupyter. That's a great
52:51 environment. But like, there are other ways to develop software.
52:53 Why does Python only run in this weird web browser thing?
52:56 Right, exactly.
52:58 Speaking of this, this is another, I think this is another reason why Python has taken off so much,
53:03 just that you want stuff to be dynamic. If you're doing the sort of data science-y type of work,
53:09 you want to run your code that way, even if you're running it in an IDE in a more traditional way.
53:14 But I think Jupyter has especially, not just like, oh, you want to have like these little notebook
53:18 cells in your browser, but more like, this is the type of way you want to interact with code,
53:21 run something, change a line, run again, run that part.
53:23 Well, that's where they're coming from too. They're coming from notebook environments. And so this makes sense for a lot of these people.
53:30 And being able to just explain it, you know, on the same, just in one look, like instead of going,
53:37 here's five slides explaining what I'm about to do, or here's just the code. Now let me sit here and explain it to you.
53:44 I can literally break it down line by line. Okay, this is what's about to happen now. Let's run this and watch it happening as we go.
53:50 So for people who don't write Python full time, again, it's amazing because for them, they can see it piece by piece.
53:57 Just like, you know, my daughter, I'm just trying to teach her how to read early. And it's just like,
54:01 like break it up piece by piece. And like, you can do that when you're training young, experienced wise Pythonistas and just say,
54:09 like, hey, let's just look at what this does. And if we want to dig into it, it's almost like having a debugger in your presentation
54:16 and just being able to like stop at any point in time and go, all right, let's, let's jump in. Let's go deeper. Let's really talk about this.
54:22 Yeah. Or be able to step back two lines of any execution.
54:25 True.
54:25 All right. Just for the time sake.
54:27 I started using...
54:28 Go ahead. Last thought, Reuben. You get the final thought on this one.
54:30 I started using more and more markup in my notebooks as well to like sort of document what I'm doing explicitly and sort of,
54:38 instead of just using hashtags and comments. So it becomes much more obvious with bullet points. I think people are enjoying that as well.
54:45 Yeah, that's great. And that's, I mean, that's part of the Zen of notebooks. All right. And you're up next. The random choices selected you.
54:52 Okay. So my big story for this year is very small story, a microscopic story. It's COVID. It's the coronavirus,
55:00 which I think for the first time ever, it's the topic that everyone is speaking about in every country,
55:06 every walk of life, like whoever I talk to, wherever they are, this is the only thing people talk about
55:11 because it has such a profound effect on everything we've done. Now, you know, this is a Python show.
55:16 So we'll talk about the Python aspect of it. And I'm not trying to minimize at all the extraordinary pain
55:21 that people are going through physically, medically, emotionally, financially, on, on, and on.
55:27 But Python is considered, has continued sort of chugging along throughout this crisis. In fact,
55:33 like we've seen that big companies, high tech companies are actually among the winners in this
55:38 as the whole world has gone digital and companies are hiring Python developers. They're increasingly
55:42 desperate for Python developers. The number of people in my corporate training classes, who, when we go around,
55:47 everyone introduces themselves, who were hired in the last six months is amazing to me. Like these are
55:52 people who are working from home, were interviewed from home, hired from home, and are now doing training
55:57 from home as their companies sort of grow in interest and power and everything. So people who have Python
56:03 skills have continued to be, and I would even say are increasingly in demand, which is amazing. The bad news
56:09 among the bad news is of course, so I mentioned this before, Python and all the other meetings and meetups
56:15 and gatherings have suffered as a result. The good news in this front is I've been able to speak at
56:19 many more conferences than I would have been able to because, hey, I can attend the conference from my
56:24 home office. I don't need to fly anywhere, go anywhere. But you know what? All of these conferences,
56:29 these online solutions are still really lacking. At the end of the day, as much as we want to say,
56:34 we're virtual, we're online, we communicate this way. And that is an important part of things,
56:38 that face-to-face contact, that personal contact is really missing. And I'm really feeling it. I've only been
56:43 doing conferences for a few years now. And boy, I really miss being in the same room as other people
56:47 and talking to them and chatting and just sort of randomly bumping into people. And then you also
56:51 have the financial aspect of it that someone was mentioning earlier, the PSF, their big fundraiser
56:56 each year is Python. And I'm sure it was a hit for them not just not to have it this year, but to have
57:01 to cancel the venue. And I am extremely skeptical that's going to happen in person. I know EuroPython
57:06 already said it's not happening in 2021. And we'll have to see exactly how this affects the community
57:12 going forward. I'd say so far, we're doing okay. But you know, here's an opportunity for someone to
57:17 figure out how can we do conferences online that are effective in a closer way to what we've been
57:23 doing so far. The news is, I would say, unbalanced good for Python and for people who know Python,
57:28 but still pretty, pretty bad overall. And also add that like these vaccines, I mean, boy, oh boy, if they
57:35 work, this is going to be like, I'm super not as a biologist or anything, but I'm so amazingly impressed
57:40 with all the science and the work that people have been doing on this front. And I think this has a chance
57:46 also to affect our lives moving forward, how they develop them.
57:49 They just need to make a PyCon bubble. So in the United States, the NBA was continuing to play because they
57:55 they had a bubble where they isolated all the players for however long, right? So we just all go to somewhere
58:02 and bubble up for however long.
58:05 Then we can have our conference online.
58:06 I'll isolate with you guys for a month.
58:08 I don't know if my family will let me do that.
58:10 Jay, we'll just do it in San Diego, man. It's nice there.
58:12 Okay, I'm all for it.
58:13 Coronado Island, we'll just get a section of it, okay?
58:15 Yeah.
58:16 But we're not mandatory quarantine for like conferences. I just did two-week quarantine here to be able to enter
58:22 Australia.
58:23 Yeah, just in Australia.
58:25 Make PyCon in Australia.
58:27 That sounds okay to me.
58:29 Problem solved.
58:29 Well, I mean, to be fair, it's expensive. So I wouldn't, you know, it's like, you know,
58:34 would you want to pay like, you know, your conference plus two weeks at a hotel in order to do that?
58:40 I don't think that'd be even less inclusive than a lot of these conferences already are.
58:45 I don't want to take all of this thunder.
58:46 But one of the first conferences that I watched was, Cecil, please remind me now because I'm blanking.
58:53 That's how long of a year it's been.
58:54 The conference that you helped put on.
58:56 And the Juneteenth Con.
58:59 Yeah.
58:59 Yeah.
58:59 And with that, I mean, one, great conference.
59:03 I'm sorry I screwed up on remembering the name.
59:05 That's my fault, not yours.
59:07 But also the sheer fact that that conference was organized in two weeks and it was an amazing
59:14 conference.
59:15 Like the ability.
59:16 And that could never have been done if it was in person, right?
59:19 Yes.
59:19 So like the accessibility that you're providing to new speakers, people that normally would
59:25 not be able to get up and give a presentation.
59:27 Like I've had that conversation so many times of like the type of talks that I like to create
59:32 are not the type of talks you see at PyCon and there's a reason why.
59:35 And it's not a bad thing.
59:37 It's just, it is what it is.
59:38 And I think when you're able to say, you know what, let's do a conference.
59:43 Let's make this happen.
59:44 Let's just get up.
59:46 We can have fun with it.
59:47 I've seen some conference talks that were literally small budget films.
59:51 Like they had multiple casts.
59:53 I've done transcriptions on conference talks that literally had, like they gave me the script
59:58 and said, all right, here you go.
59:59 So like when you can actually do things like that and think outside the box and use this
01:00:06 time to readjust the needle.
01:00:09 There was a good podcast episode on more than just code.
01:00:13 I believe not more than just code.
01:00:14 I don't remember what it is.
01:00:15 I'll find it greater than code.
01:00:16 That's what it was.
01:00:17 And they said, if we haven't taken this time to do something better when things are different,
01:00:23 when things have improved, then shame on all of us because yes, this sucked, but it caused
01:00:28 us to think so much outside the box that we should be able to take all that knowledge with
01:00:34 us when we can get back in the box and just have a ton of fun with it.
01:00:37 Yeah.
01:00:38 I think a lot of opportunities been made available for people to attend conferences and for people
01:00:43 to get jobs where companies would previously say, no, you have to move to San Francisco or
01:00:48 to Omaha or whatever.
01:00:50 It's like, well, you know what?
01:00:50 No one's going to the office.
01:00:51 Let's try hiring from the best in the world instead of the best in Nebraska or whatever.
01:00:55 I think that might be the biggest fallout of this, Michael, is just the change in everything
01:01:01 being centrally located in Silicon Valley.
01:01:03 Yeah.
01:01:04 I've heard of a lot of people that actually just have jobs in the Valley that have moved
01:01:09 back to where their parents are because it's like 10 times cheaper or something like that.
01:01:14 And they're not going to want to move back.
01:01:16 Yeah.
01:01:18 Have you heard that some companies are then readjusting their salaries?
01:01:21 They're saying, well, if you live outside of the Bay Area, then it's cheaper.
01:01:25 So we're going to cut their salary as a result.
01:01:27 Yeah.
01:01:27 But people have always been doing that.
01:01:30 That's like, unfortunately, not new.
01:01:31 So if you're listening and this happens, you can say, well, you no longer have to pay
01:01:37 $17 million for my office area.
01:01:40 So let's call it an even swap.
01:01:42 Just keep a virtual address in the Bay Area.
01:01:48 Exactly.
01:01:49 My PO box is right down on Fifth Street.
01:01:51 All right.
01:01:51 Last one.
01:01:52 This random choice was easy because we're down to our final.
01:01:55 Excellent guest.
01:01:56 Matt Harrison, what do you got for us?
01:01:57 Okay.
01:01:58 My thought was just on sort of the hardware aspect of things this year.
01:02:02 So I have a daughter who started college this year for better or for worse.
01:02:07 And she's learning both C++ and Python right now.
01:02:10 Her linear algebra class has a Python lab, which I think is awesome.
01:02:14 I wish I had that.
01:02:15 But I was actually helping her with some homework.
01:02:19 I wasn't doing it, but she was like, I can't figure this out.
01:02:22 So I was her rubber duck the other night.
01:02:25 And her issue was allocating memory, right?
01:02:27 And so one of the things that's nice about Python is you don't have to worry about allocating
01:02:33 memory.
01:02:33 And she got all the output, but she was just double freeing a pointer here, which they checked
01:02:39 on submission.
01:02:40 So Python's now, now we're seeing Python.
01:02:43 And I'll just tie this.
01:02:45 Like I have a client who wants next year wants me to do a training on GPUs with Python, which
01:02:50 just goes to show like my clients tend to be big companies.
01:02:53 And so big companies are now leveraging like specialized technology to do things very quickly, right?
01:03:01 And if you have a GPU, you can get 10,000 times performance that you get out of a CPU.
01:03:08 So I think that's super exciting.
01:03:09 There's the Rapids project, which is heavily sponsored by NVIDIA.
01:03:14 And I'm super impressed with that.
01:03:17 They're basically like taking well-known APIs and basically saying, hey, your code basically
01:03:23 change an import or, you know, with the change of an import and this hardware, your code will
01:03:28 run X times faster or whatever.
01:03:31 And so I think that's super compelling and exciting.
01:03:33 Not that necessarily everyone will have access to those sorts of things, but it's now, it's
01:03:37 now getting to the point where it's becoming more common.
01:03:40 On the note of hardware, I think another thing that was really interesting this year was the
01:03:44 Apple M1 chip coming out.
01:03:46 I actually bought a beefy PC this year, having run a MacBook for 15 years, just because due to
01:03:53 Corona and whatnot, I needed something beefy to start doing virtual sharing and presentation
01:03:59 like this and my MacBook just wasn't cutting it.
01:04:01 But the thing I don't like about my PC is that it has, it sounds like it's going to take
01:04:08 off every time I start doing something, right?
01:04:10 Like modern Intel chips can take us to Mars if they want to.
01:04:14 We just need to like make a huge drone out of them.
01:04:17 And so I'm super excited to see, like, if you can get a silent MacBook that, you know, is
01:04:24 super powerful, runs faster than Intel chips.
01:04:27 That's super compelling, especially if they allow you to get a little bit more RAM, which
01:04:31 from the machine learning side is interesting to me.
01:04:33 But I'm also excited about the competition factor of that.
01:04:37 I think like Intel and the chipset has sort of stagnated for the past couple of years.
01:04:42 We've sort of run out of the end of Moore's law per se.
01:04:46 So I think both the GPU and the M1, it'll be interesting to see what the competition is from
01:04:52 the PC manufacturers if they're going to, you know, do a similar everything on a chip thing
01:04:58 or just sort of go with what they've been going with.
01:05:01 I think competition is good.
01:05:02 And so I'm excited that Apple did this, even though there's going to be some growing pains
01:05:07 and Python might have some issues at first, but I think in the end, new technologies, new
01:05:11 hardware that allow us to write at high levels and not have to worry about freeing and allocating
01:05:16 memory, which again, a lot of people are using Python don't care about that.
01:05:20 They don't want to be programmers.
01:05:21 They want to leverage great code, stand on the shoulders of giants and the latest and greatest
01:05:26 software and hardware and have it be fast.
01:05:29 So I'm super excited about the future with them.
01:05:32 Yeah, I'm really excited about both these things.
01:05:34 Like the whole GPU revolution is incredible.
01:05:36 And the Apple M1 stuff is going to be really, really interesting.
01:05:40 Like you, I bought a maxed out Mac mini.
01:05:43 I actually had already ordered a top of the line MacBook Pro 16 inch.
01:05:48 And then that came out.
01:05:49 I started seeing the reviews.
01:05:50 I'm like, you know what?
01:05:51 Forget it.
01:05:51 I'm not getting that thing.
01:05:53 I'm getting this new one to try it out.
01:05:54 And it does have some drawbacks, like Docker doesn't work right away.
01:05:57 Maybe it will, maybe it won't.
01:05:59 But I have a 2018 MacBook Pro.
01:06:01 That's pretty good.
01:06:02 I have a SimRacing 16 core machine over there.
01:06:06 Like I've got plenty of Intel stuff to work.
01:06:08 So I'm going to try to jump on this.
01:06:10 And I think the interesting Python angle here, besides just having stuff to run our code in
01:06:14 is, you know, Inu's talked about like her CI didn't support 3.9 right away.
01:06:18 Well, who's CI is going to build wheels for Apple M1 straight away and things like that.
01:06:23 There's going to be some interesting growing pains, especially on the data science side,
01:06:26 as this true platform shift happens.
01:06:28 It's fun that you mentioned that because actually, yeah, when this came out, we were also thinking
01:06:31 like, ah, maybe we should get one of these.
01:06:33 You know, we want to make sure spacey compiles properly on it and we can really, you know,
01:06:36 optimize for that.
01:06:37 And did you guys get one?
01:06:39 Yeah.
01:06:39 Because someone has to do it or so, you know, not yet.
01:06:41 No.
01:06:42 Also, it's a bit difficult with the traveling.
01:06:43 But like, yeah, that's kind of when we have other priorities too.
01:06:46 This is not, I wouldn't put this like at the very top, but like, it's definitely something
01:06:50 we want to do.
01:06:50 But at the same time, we also want to keep optimizing for CPU.
01:06:54 Like that's the other thing.
01:06:55 Of course, you know, even all the new, these new NLP models, all of that stuff, obviously,
01:06:59 runs great on a GPU.
01:07:00 And we'll see a lot of improvements.
01:07:02 And we also see this become much more available and cheaper for people to use.
01:07:06 But at the same time, we're still, we're still optimizing our tools and libraries for CPU.
01:07:10 Like you can run it on your random laptop.
01:07:12 And also it's still for a long time, it will be cheaper still.
01:07:15 If you just, you know, you want to run lots of machines and you can get those, you know,
01:07:19 much cheaper in the cloud.
01:07:20 And if you can parallelize, you can train, train your models very efficiently on CPU.
01:07:25 If you can get it to work.
01:07:26 Yeah.
01:07:26 That will always be cheaper for a long time.
01:07:29 There's a lot to say about just the overall cost of computing as a whole.
01:07:34 I mean, this is great.
01:07:36 This is $10.
01:07:36 And I mean, I can run a lot of stuff on that.
01:07:39 You're holding up a circuit.
01:07:41 Well, this is the Adafruit thing just for the people who are not on the video.
01:07:44 Oh, yeah.
01:07:45 Sorry.
01:07:45 I'm holding a Raspberry Pi Zero W.
01:07:47 So it's like, you know, four gigs of RAM, like enough.
01:07:51 You can buy a 64 gig like flash drive for $3 now.
01:07:55 Like it's amazing.
01:07:57 Like just the overall cost of compute has dropped so much.
01:08:00 I mean, what was it?
01:08:01 The, what is the Raspberry Pi?
01:08:03 400?
01:08:03 400 where it's just, it looks like a keyboard, but it's actually a whole computer.
01:08:07 Yeah.
01:08:07 So it's like, as we continue to do more and more, we're doing it with less and less and it's cheaper and cheaper and cheaper.
01:08:16 And most of us are coming from someplace where the cost of living is too damn high.
01:08:21 And we're able to say that we can afford to buy a $15 Pi Zero and not think about it too hard.
01:08:26 But the fact that we're getting to that point where you can have people all over the world where the question isn't anymore, how do I get a computing device in my hands?
01:08:35 It's like, okay, now I have some choices and they're all affordable.
01:08:39 Like to me, that's, we're going to see a lot of things come where Brian Okken is right now, where VS 2103 is in the future.
01:08:46 There's going to be a lot of great things coming.
01:08:48 And yes, I'm looking at chat.
01:08:50 I have my kids to have one of those one laptop per child's in their bedroom over there, right?
01:08:55 Which I think that the Raspberry Pi 400 is sort of...
01:08:59 It's the next gen of that.
01:09:00 It's actually something that makes sense.
01:09:04 Everyone has a TV, right?
01:09:05 And you can just plug it in and you're not in somewhere.
01:09:09 I mean, you're in Linux.
01:09:10 So yeah, you're in a weird environment, but you can run...
01:09:13 Is that one of the laptops with the hand crank on it?
01:09:15 Yeah.
01:09:16 Well, it has a little wings.
01:09:17 Mine didn't have the hand crank, but...
01:09:19 Okay.
01:09:19 I actually like, I kept hearing about Raspberry Pi.
01:09:22 And so I decided to order one recently and I haven't done anything with it.
01:09:25 I like just came a few days ago, but I'm looking at this thing.
01:09:28 I'm like, oh my God, this little card here that cost me less than a hundred dollars, a lot less than that,
01:09:34 is more powerful than the computer I use to run my entire business for years and years and years.
01:09:39 It's just astonishing to me.
01:09:40 Yeah.
01:09:41 So I think that's probably a good place to round out the show.
01:09:44 Like the future is so exciting.
01:09:45 And in some ways we're like kind of living there, right?
01:09:48 Some of these things that are coming out are so amazing.
01:09:50 And I just want to say thank you all to you all for being here.
01:09:53 You're all doing such amazing work and it's really humbling.
01:09:56 You all took time from crazy schedules, from traveling, from weird locations to just be here and make this whole event happen.
01:10:02 Thank you for listening to Python Bytes.
01:10:04 Follow the show on Twitter via at Python Bytes.
01:10:07 That's Python Bytes as in B-Y-T-E-S.
01:10:10 And get the full show notes at pythonbytes.fm.
01:10:13 If you have a news item you want featured, just visit pythonbytes.fm and send it our way.
01:10:17 We're always on the lookout for sharing something cool.
01:10:20 On behalf of myself and Brian Okken, this is Michael Kennedy.
01:10:23 Thank you for listening and sharing this podcast with your friends and colleagues.