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