Transcript #400: Celebrating episode 400
Return to episode page view on github00:00 Hello and welcome to Python Bytes, where we deliver Python news and headlines directly
00:04 to your earbuds. This is episode 400. How about that? I'm Michael Kennedy.
00:12 And I'm Brian Okken.
00:13 And this episode is brought to you by Scout APM. Check them out. Links in the podcast player's
00:18 show notes are on the website, and we'll tell you more about them later. Connect with us over
00:22 on Mastodon. Links in the show notes. And hopefully you're watching us live now on Mondays. Usually
00:28 you can find out by going to pythonbytes.fm/live. And usually we have the next one
00:33 scheduled and you get notified about that. And for those of you who would like, even if you missed
00:38 the show, a quick digest, an artisanal handcrafted digest of all the things we talked about for the
00:45 week, just become a friend of the show, sign up for the newsletter, pythonbytes.fm, click on newsletter.
00:50 Well, before we get into the topics, officially, Brian, I think we got to say a little bit something
00:56 about 400. Yeah, it's quite a big number.
00:59 So big that you wore an amazing hat with a butterfly.
01:01 Yeah.
01:02 That's a cool hat. Well, I honestly, I want to start by saying one, thanks to you. Two,
01:08 thanks to the thousands and thousands of people who listen every week. Make this possible,
01:13 honestly. And I really, really appreciate it.
01:15 Yeah. Thanks to you too. Whatever year it was when we started, you reached out to me and said,
01:21 hey, well, do you feel like doing a podcast together? And I really wouldn't have thought
01:25 we would have been at 400 episodes. It's pretty cool.
01:27 I know. It's incredible. And I thought, well, we don't have really any guests or a lot of like,
01:32 you know, forum stuff. So let's celebrate this. I asked ChatGPT to say, I said, look,
01:38 there's this big milestone. Could you just give us a quick celebration sort of thing? And I think
01:43 there's a few things that are notable before I read this off. It's pretty short.
01:46 Okay. But I think it's notable that it knows about you, knows about me, knows about the show,
01:51 knows about what the show is about and the topics we've covered. So anyway, here we go. This is
01:55 ChatGPT celebrates episode 400 of Python Bytes. Welcome to the big 400 Pythonistas. It's hard to
02:02 believe we're celebrating the 400th episode of Python Bytes. From the early days of byte-sized
02:07 Python news to becoming the source of all things Python, it's been a wild ride. We've laughed over the
02:11 quirks, gasped at new libraries and said farewell to the GIL together. Whether you're
02:16 a seasoned developer, a curious learner, or just here for the witty banter, you've been an essential
02:20 part of this journey. To Michael and Brian, you've built a community that turns import this in more
02:26 than just Zen. It's a family of passionate Pythonistas. Your dedication, insight, and humor makes this show
02:32 more than just tech news. It's a weekly celebration of what we love about Python and why we keep coming
02:37 back for more. Here's to the next 400 episodes. May your code be bug-free, your test pass on the first
02:43 run, and your Python version. Always be up to date. Rocket snake emoji.
02:47 That's pretty good, isn't it? Actually.
02:49 Yeah, yeah. I'm touched. ChatGPT, I didn't know you loved me that much.
02:53 I know. Thank you, ChatGPT.
02:54 And Michael, that's just touching.
02:56 It is.
02:58 It's pretty cool, actually. I like that. Turn your, turns import this into more than just Zen.
03:04 Indeed. I see some thank you out in the audience, and thank you, all you guys out there.
03:09 With that, shall we talk about whatever you want to talk about first?
03:12 Sure.
03:13 As we've done 399 other times, apparently.
03:16 Yeah. Let's talk about Python, specifically Python 3.13. It's just right around the corner.
03:24 The official release is scheduled for the 3.13.0. It's supposed to come out on October 1st. That's
03:32 just right around the corner. That's hard to believe. So 3.13.0 candidate release, or RC2,
03:39 is out. So that was released September 6th, a few days ago. And I'm linking to a, oh, I didn't link
03:48 to the right thing. But there is, oh, well, I'll just talk about it here. Anyway, it comes out October
03:54 1st. Lucas Lenga, which we will link to his post, has a post to talk about it as well. Also talks about
04:02 a few other releases. There's security releases for 3.12, 3.11, 3.10, 3.9, and 3.8. That's a lot
04:12 of releases. And an interesting thing about the older releases, I'll cover those first,
04:17 is that 3.12 has a Mac release. It has binary releases. And the Mac release is only for 10.13
04:28 or newer. If you've kept up to date fairly recently, it should be fine. Because I looked at mine and it
04:34 was way past that. But there are limits to the macOS binary version. And all the others, like 3.11
04:44 3.11 through 3.8, they don't have binary distributions built, which is interesting.
04:49 But anyway, so what we're really excited about is 3.13. Of course, it's coming out right around the
04:56 corner. There's a call to action here that is a strong encouragement for third-party Python projects
05:03 and maintainers of third-party projects to prepare your projects. Because people will be upgrading in
05:09 October because all the last upgrades have been so easy, people are going to upgrade. So make sure your
05:14 your projects are ready. Go ahead and start testing on them. And if there's any issues,
05:20 submit to the bug tracker. And then also, please keep in mind that the RC2 is a preview release.
05:29 So it's close to the final release, but it's not recommended for production environments. So yes,
05:34 test with it. Don't run in production yet. So that's cool. The one thing that I thought was
05:39 interesting. So I've kind of migrated. We talked about this recently is upgrading your local Python
05:48 Python with UV Python. You can't use that for 3.13. So you still have to use python.org or some
05:54 other mechanism to install 3.13. You can't do that through UV Python yet.
05:58 Yet. Yeah. Actually, one of my items touches on that. So we'll talk about that shortly.
06:03 Okay. So yeah. Yay. I'm excited. Yay. Henry's running around in the audience says,
06:08 we're also going to have to change building wheels with 3.12 to be 10.13 plus and see how build
06:16 wheels. Interesting. You know, you think about the cascading effects of all these requirements,
06:20 you know, and 10.13 being the macOS version. Yeah. Was that, was that when they split and
06:25 didn't like the Intel versus whatever the other thing is, or. I think it may have been, but the
06:33 current version does support the Intel ones. I'm pretty sure it's just, well, as of today,
06:37 they're supposed to announce a lot of that Apple's, Apple intelligence, their AI. Oh boy. So that I
06:44 believe is going to be one of the hard splits as well as like that stuff. I don't think it's going
06:48 to work on Intel, but we'll see what they say. Okay. I think that's literally going on right now.
06:52 As we speak the Apple keynote thing, which is a weird one hour ad that people look forward to.
06:57 Okay. Such is the world we live in. All right. Let's carry on with a pretty sweet transition
07:03 from UV to talking more UV here. So I wrote up, you know, we've been talking about UV recently and I
07:10 couple of different, there's a kind of a little mini extra, extra, extra all around one topic. So
07:15 I wrote up an article about how I'm using the UV Python thing that you just mentioned, Brian,
07:22 using that to basically dramatically improve how we build Docker images. One of which runs or
07:29 several of which I guess run Python bytes, Python bytes set of M gives you the RSS feed, the files,
07:35 all that kind of stuff. Right. Yeah. So people can check that out, but the short and long of it is
07:40 if you get down to the bottom one, it comes with an example, a little flask app, multi, multi-tier,
07:44 well, multi-image, not multi-tier flask app that shows how to go from basic Ubuntu image to having
07:51 whatever version of Python you want with the virtual environment set up on it, including setting up
07:56 your dependencies and a web server and all of that in seven seconds from nothing like a dash,
08:02 dash, no cash style, a build. And that gives you a base image. You can just kind of keep chilling.
08:07 And then if you depend, you take an app and you build it on top of that, like a flask app or some
08:11 other kind of Python app, I got it building around seven to eight, 700 to 800 milliseconds. So less than
08:17 a second, which is awesome. Hey, so, you know, we talked about this back on 396 and 398. And we've been
08:25 kind of hitting a lot, but I just recently had Charlie Marsh from astral on, and we talked about
08:31 this and I asked him things like, so I see you don't have the, it didn't have the latest 312 for
08:38 a couple of days. And, I noticed that you don't have a 313 and basically his thinking. I,
08:46 if I remember it correctly is more or less, we plan on supporting a version before it becomes final,
08:53 before it becomes stable and gets released. So by the time 313 gold, gold master, right?
08:59 Whatever it comes after the official 313 zero release, I guess comes out. It should be available
09:05 in UV, but I'm not sure how much before then.
09:07 Yeah. Well, and we also heard from, so Henry Schreiner says 313 just got merged in, in the same
09:13 place, which is, which is that Python built standalone. Also the 313 T is now in a PR.
09:20 So it, Oh, interesting. We should free threaded version. Yeah. So hopefully, yeah, I think,
09:25 and that was my final thing to point out is if people are like, well, okay, when I say UV Python
09:31 or what I actually, I don't say UV Python necessarily. What I do is I create a virtual environment with UV
09:37 and I just, I want it. I tell it, I wanted this version of Python. Oh, okay. Right. And it goes,
09:42 Oh, you want that version of Python? Either we've already cached it or if we don't, we'll just download
09:46 it from Python build standalone and then put it there for you. So if your common working artifact
09:52 is a virtual environment, then you don't have to necessarily have, it doesn't even matter if you
09:56 have system Python, like literally you could not have Python on your machine and this would still
10:00 get you a virtual environment with the right version of Python that you ask. But the source of all this
10:06 also, I learned about this from talking to Charlie last week is, Python build standalone. If you look
10:13 at the releases and like, let's see, for example, on the latest release, there's 773 different builds.
10:21 There's something. Wow. Look at that. So you can see here, there's cPython 3, 10, 14 with something
10:27 on x86, 64, four PCs on windows with this thing. You know, there's just so many variations. So basically
10:35 when you say UV create me a virtual environment with this Python, it's going to go on through those 773,
10:40 find the one that's the right bit and just download it and put it there if it's not already cached.
10:44 So anyway, that's the whole story. Okay. Okay. So that thing has that, that one thing has,
10:50 has a, 3, 13. It just hasn't been released yet then. So, or I guess we're waiting on that release.
10:55 Yeah. So, so thank you, Henry. That, that, gives us some more information. I imagine that it's really
11:00 down to just what Python build standalone is doing. And then UV just give me the list of options and,
11:07 and let me find things that, you know, match this operating system. Something like that.
11:10 Well, it sounds like both of us went down the same rabbit hole, but it is kind of neat to find out
11:15 where the source of this is so that I know that wasn't that hidden, but it did take a little bit of
11:20 looking to figure out. Yeah. Well, they could have been building it themselves. You don't know right now. Like you don't know what setting it. There's all sorts of stuff
11:27 that's interesting. And there's also, I recall correctly, Charlie said there are different
11:32 build optimization settings for Python build standalone, then say what you get off of python.org
11:38 or out of homebrew. It's, it's interesting. For example, like profile guided optimizations and things
11:44 like that. And I don't remember which had, which, which is better, but I feel like the build standalone
11:49 came out pretty strong there. Yeah. Before we move on, Brian, let me tell you real quick about
11:54 scout APM. They're big supporters of Python bytes. So we appreciate that very much. So if you are tired
12:01 of spending hours trying to find the root cause of issues impacting your performance, then you owe it
12:06 to yourself to check out scout APM. They're a leading Python application performance monitoring tool,
12:12 APM, that helps you identify and solve performance abnormalities faster and easier. Scout APM ties
12:19 bottlenecks such as memory leaks, slow database queries, background jobs, and the dreaded N+1 queries
12:24 that you can end up if you do lazy loading in your ORM. And then you say, oh no, why is it so slow?
12:31 Why are you doing 200 database queries for what should be one? So you can find out things like that.
12:34 And it links it back directly to source code. So you can spend less time in the debugger and
12:39 healing logs and just finding the problems and moving on. And you'll love it because it's built
12:43 for developers by developers. It makes it easy to get set up. Seriously, you can do it in less than
12:48 four minutes. So that's awesome. And the best part is the pricing is straightforward. You only pay for the
12:54 data that you use with no hidden overage fees or per seat pricing. And I just learned this, Brian. They also have,
13:02 they provide the pro version for free to all open source projects. So if you're an open source
13:07 maintainer and you want to have scout APM for that project, just shoot them a message or something on
13:12 their pricing page about that. So you can start your free trial and get instant insights today. Visit
13:18 fm.com/scout. The link is in your podcast player show notes as well. And please use that link. Don't
13:23 just search for them because otherwise they don't think you came from us and then they'd stop supporting
13:29 the show. So please use our link by them by set of him slash scout. Check them out. It really supports
13:34 the show. All right. Over to you. Cool. Cool. I wanted to talk about read the docs for a little bit. So
13:40 it just seems like, you know, read the docs been around forever, right?
13:44 Yeah. So, so there's an article by Eric culture, 10 years of sustainable open source. And it's a,
13:54 it's a little bit of some, some cool history here. so one, I, we totally rely on, read the docs,
14:01 and, and the, all the tools around it. So read the docs apparently started in a, with a 40 hour,
14:10 48 hour open source sprint in 2010, 48 hours. Wow. So two days, I guess, and it grew to become a
14:18 successful part of the Python, Python ecosystem and other, open source projects. And, yeah,
14:24 obviously it's just been around 2010. but I guess that's, that's about the time that I really started,
14:30 jumping in and being part of the Python community and not just part of just a user of
14:35 Python, but, but part of the community. So, so that's why it looks like, it seems like it's
14:40 been there forever for me. and in 2014 they created read. So read the docs.org is the open source
14:47 thing. Read the docs.com, com was the, is in 2014 and there's links to the announcements from
14:56 2010 for announcing read the docs and the announcement for, read, read the docs for
15:01 business, the.com. So this is kind of an interesting story about how to make a, a, a service that, that helps,
15:10 open source communities all over the place, and how to make that sustainable. So they're still
15:15 sustainable, which is cool. So what is the sustainability model? How do they do that? Because there's, there's four full-time
15:22 people working on this, which is not that big. I mean, four people, there's probably a lot of, volunteer
15:28 volunteers on the open source site also. but for full-time people, that's pretty cool. Anyway, there's, the.org
15:35 side has, single non-tracking ads. And I think they were one of the first that I was aware of that did, did like a single,
15:44 just like ethic ad ethical ads or something that just had ads, but it wasn't tracking you at all,
15:50 which is how ads should be, I think. and I, I'm totally okay with that to help them sustain their
15:55 model. And then the.com is a paid service that helps companies for private repos and additional,
16:01 they have other benefits also, but sort of read the docs for companies. and then it also talks about
16:08 things that didn't work, which I love this. I love the discussing the parts that didn't work.
16:12 I like, have you tried this? one of the things was, just trying on trying, donations and
16:18 other optional support, and it just didn't work at all. That left people with, mental health issues
16:24 and burnout. This is, that's terrible. the other thing was, consulting services where you
16:30 think about that, like maybe offer services for people that to pay, but, the bad downside of
16:35 that was it took away from, time that they wanted to work on the main project. they
16:41 experimented with grant funding and that was cool. Cause they got some, like a blob of money at a time,
16:45 but it's a one-time thing and it's not that easy to keep going and getting more grants. So the current
16:51 model is the paid service plus the advertising. And, that's cool. they talk about some lessons
16:57 learned, which is neat. basically, you don't get extra points for being bootstrapped.
17:02 people will compare you to VC funded companies anyway, which is it's, it's cool that they call it
17:08 out because that's obvious, but also sometimes not obvious. even if you're community driven,
17:13 bootstrapped, you don't get any points for that. We, we still expect you to be perfect. the other
17:19 thing was, that keeping trust in the community was the most important thing. and, yeah,
17:25 it, they said it's cliche, but trust is hard to earn and easy to lose. definitely. and they,
17:32 they can't, can't maximize profits. unless you keep trusting the, with the community, which,
17:38 definitely, support that. the, the one part that I thought was one of the reasons why I
17:44 highlighted this is because this is a lesson I think that can go, not just for people trying to sustain a,
17:50 funding model, but just, lots of open source projects can, can listen to this.
17:55 And the lesson is contribution is easier in less complex parts of the code base.
18:00 So they've noticed that they've got, they've got their core stuff, the read the docs.org repo,
18:05 the core stuff that is got some complex stuff in it and it's hard to get people to help out,
18:11 but there's other things like contributions to this Sphinx theme or extensions or small Python or
18:17 JavaScript projects that are work alongside of it that are easier to get people to contribute to.
18:23 Cause they're, they're smaller, less, I guess, less complicated bits of code. I think a lot of
18:29 open source projects probably could do something like that of separating out whether the code is and say,
18:35 if you'd like to contribute, maybe don't touch this part. Cause it's kind of hairy and you might,
18:40 it takes a while to get into, you can, but it's going to be difficult. and,
18:45 I've noticed that with lots of projects. So anyway, congratulations to all of them for 10 years.
18:51 That's awesome. And, and then I was reading something and I found, I learned something is that
18:57 there's, there's, I kind of associate read the docs with Sphinx only, but that's not true. there is
19:03 now, there was a, effort to separate some of the customization and they have a different build process
19:09 going on now and you can, the Sphinx or the read the docs build system now supports any
19:15 documentation tool or it should, which I didn't know about. So that's, yeah, that's cool.
19:20 Almost like a general static site platform. Probably. Yeah. Yeah. Anyway. Yeah. Congratulations.
19:26 It's a pretty important section of the Python community and also got some cool Python,
19:32 some Portland ties as well, which is cool. Yeah. Yeah. Really helps humanize the Python space.
19:38 Wouldn't you say Brian? Yeah. Which is what I want to talk about next. This project by Hugo. I know you've
19:45 pointed this out before Brian, I believe I can actually get to him. There we go. Hugo van Kenamande,
19:51 CPython core developer and mini, mini project maintainer. One of projects is humanize. And I recently,
19:59 when I've written this codes for in ice and, you know, small scale before, because I kind of needed it.
20:05 And if I knew about this, I just wouldn't, but also I recently just started using it and it's super
20:11 simple, super easy to adopt. You see examples of it right here on the GitHub screen. If you visit their
20:16 GitHub repo, right. And see where it says seven months ago, last week, last year, that kind of stuff,
20:22 instead of just putting a date. Yeah. It's that kind of stuff that humanize does, but for different
20:27 things. So if I go over to, I love all these ties from falling on from you, from read the docs. If I go over to
20:33 read the docs for them and I wait apparently and it comes up. Okay. So then they basically have four
20:39 areas that are relevant. It works in different languages, many, many different languages, which
20:44 is cool. It mostly works in numbers, but as I pointed out, it also works on time. So if we look at time,
20:49 it has a natural date. Some of these don't have great examples. For example, the time and file size could
20:56 have really nice dates. So the one I mentioned with the GitHub is natural delta. It would say things like
21:04 a year ago or two years ago, or in 13 seconds, stuff like that. It has a similar natural time
21:12 and precise deltas. If you want those kinds of things also as for file size. So it'll say things like 300
21:18 bytes, 3.0 megabytes, 2.9 kilobytes or whatever. Right. So you can just give it a number and tell
21:25 it, you know, here's how many bytes it is. Make this friendly and it'll kind of figure out the right
21:30 scales, a megabyte, kilobyte. You don't want 0.000 megabytes. You just want, you know,
21:36 switch that to kilobytes or bytes. Right. So file size is cool. But the one that has tons of stuff going on
21:42 is number. So you can have an associated press style number. I guess this must be the way they're
21:49 a convention when you're writing articles on how to speak about numbers. So if it's a small number, use
21:54 written out words like F I V E for five. But if it's, you know, one zero zero one two one seven, you don't
22:02 you don't write that out as a huge long thing. You just put the straight number. Right. So I think the cutoff is
22:08 10, which is pretty cool. It has clamp. And so you can talk about percentiles. For example,
22:13 if you say a really, really small number and you say the floor is 0.01%, it'll, or just that number
22:20 as a ratio, it'll say the number that you have for this, the value is less than 0.01. Oh, nice. Or you
22:27 can do it as a percent here. And then you can say this one, this particular value is greater than 99%, or it's
22:32 in the top 10%, or you can just say like under 1 million, which is pretty awesome. Right?
22:38 Yeah. Yeah. So what else have we got here? Fractional. So this just takes, you know,
22:43 floating point numbers and puts them into fractions like one and three tenths or one and a third or
22:47 something like that into comma, this one I would just do with formatting, but you can have it put commas
22:52 in for separators into word. This one is really nice. So if I have one with seven zeros, it'll say 1.0 million.
23:00 Or if you put in 1.2 billion, but as like integers, it'll just say 1.2 billion or all kinds of things.
23:07 You give it precisions, et cetera. Nice. Right? It's very cool. I like that the scientific stuff.
23:14 The scientific is good. The metric is really nice. If you give it a base measurement, like Watts or
23:21 grams or something, and then you say, give me this number in that unit system. So for example,
23:27 if you save 1500 in terms of volts, it'll give you 1.5 kilovolts. That's pretty fancy. Yeah. Or
23:34 Watts and you give it some huge number or say this many megawatts or really, really small one micro.
23:39 I don't know what F is in metric because to me that's Fahrenheit. So whatever.
23:43 Yeah.
23:44 And the micro stuff is cool. Cause I always have to hunt it down. I have no idea how to type a micro symbol.
23:50 Yeah. So click to the scientific one or the 10 to the powers are pretty cool. The 10 to the minus one
23:59 with a little superscript. That's neat. Yeah. Yeah. Instead of having 10 E three, it actually has 10
24:05 superscript three. So a thousand is one times 10 to the three with actual three. Like you would write it,
24:12 not the way computers have to write it. So yeah, it's really nice. Anyway, it's just, if you need this kind
24:16 of stuff really easy to adopt and understand, if not, then you know, it's still interesting. However,
24:22 if someone is out there looking to contribute to this project, I would say more examples.
24:26 The numbers have awesome examples and all the other ones are kind of, you may or may not even know what
24:32 it's going to do. So, Hey, put together some examples as a PR and ship them over to you guys.
24:36 That'd be cool.
24:37 And you know, documentation contributions are usually very welcome.
24:41 So, so yes, indeed. All right. Extras, Brian.
24:44 I just have one extra. I wanted to shout out. So I talked about that. I thought test podcast is going
24:50 to go back to testing code, even though. So it is. So I finally finished that migration and actually put
24:57 out an episode. So 222 is the 222 is the second episode of a two part series that started in June.
25:06 Sorry.
25:06 Serious cliffhanger, serious cliffhanger. So, yeah, this, so that's there. And then I got
25:13 a question. I sent out an email and said, Hey, finally have another episode out. And somebody said,
25:18 you should do transcripts. And, I guess I hadn't announced that, but transcripts are there.
25:23 I've had transcripts in the last, I don't know, like the last 30 episodes or something. So,
25:29 transcripts are AI generated. So they're not perfect. Like this is great. I gotta find one of these,
25:34 DB dot PI. That's fine. But there's like some, some dot pies that show up as dot PI and some dot
25:41 E I E is some, dot DB, like actually spelling out the DOT. This is terrible. Oh, API dot P I E.
25:50 This is hilarious. So, I could go through and try to fix this stuff. but I'm going to probably
25:55 try to hire my kid to go do it for me. but anyway, so they're there. That's all I wanted to say is
26:01 it's in it. I'm not doing this weekly. I actually talked to, to a friend of mine, Michael
26:07 Kennedy. and he said, he said, it'd be kind of cool to, to do seasons. And so I'm kicking
26:13 around the idea of doing seasons. Yeah. Well, themes. I like it. I think it'd be great. Yeah.
26:17 Anyway, that's just my extra. Awesome. I have a couple of quick, code in the castle event is
26:23 almost over and it's almost, booked and happening. So if you want to be part of it,
26:28 I'll put a link in there, please. last kind of last call. So check that out. Yeah, I know.
26:33 All right. We got some interesting email. That's it. I think I covered the Anaconda code plugin for
26:40 Excel, how it runs locally. It runs on PI script, all these good things. Cause you other features. Well,
26:46 look who sent this in. I want to make sure I give some credits. This was by
26:51 rude Vanderham. Thank you for sending this in the sub project created. And basically when you have these
26:59 Excel, Python bits of code, you have to write all the code in one function and things like that. And
27:05 there's other limitations as well. So basically he made it so you can have a lot more,
27:11 or formatting variability, I suppose. And then you just have this bit of code that will just run a
27:16 whole set of different bits of code that you can have into your workbook, which is kind of interesting.
27:21 So as a follow to that, people are interested, they can check that out and just a quick out shout out to
27:27 iStats menu. Do you iStats menu, Brian, for your Mac? No, if you want a real time stats for what your Mac is
27:34 up to as they just released a new version looks super cool. I'm just starting to play with it. So obvious
27:40 things like CPU and stuff. But if you hover over them, it'll give you tons of detail. Like macOS
27:45 is kind of hard to get a lot of these pieces of information, but it'll have uptime. It'll have
27:50 like how much power your CPU is pulling out of, or your computer's pulling out of the wall, which is
27:55 kind of interesting as a, you know, how hard is it working? Like how many Watts is it pulling? And so
28:00 anyway, that's cool. That's cool. Yeah. People can check it out. It's pretty nice. Nice. Yeah. That's it. And you want to close it out with a joke.
28:09 Aren't big episode 400? Definitely. All right. This is sort of in the theme of I'm learning
28:15 new programming languages, right? Mostly as beginners says, comes from dev humor says, beginner programmers,
28:21 when they learn a new programming language, just a shock. Is this Morty? I don't know. I think so.
28:25 Anyway. Well, that just sounds like Python with extra steps.
28:28 Yeah. Yeah, exactly. Exactly. That's cool. But why all the stuff there? Anyway, thanks for episode
28:38 400. Thank you everyone for listening. Thank you, Scott APM for supporting the show. Check them out as well.
28:43 Thank you. Yep. See you, Brian. Bye.