Brought to you by Michael and Brian - take a Talk Python course or get Brian's pytest book


Transcript #96: Python Language Summit 2018

Return to episode page view on github
Recorded on Thursday, Sep 20, 2018.

00:00 Hello and welcome to Python Bytes where we deliver Python news and headlines directly to your earbuds. This is episode 96 recorded September 19th 2018 I'm Michael Kennedy and I'm Brian Akin. Hey Brian. How you doing? I'm doing really good. All right, I'm doing great There's always something to talk about in the Python space and never gets boring Yeah, no, definitely doesn't and we're here bringing this to you today in part because of Digital Ocean sponsoring this episode So check them out at Python bytes at FM slash Digital Ocean and get a hundred dollars credit for some server goodies tell you more about that later.

00:31 Brian you found an interesting one i don't even know what to make of it here tell us about it.

00:35 I can't remember where i came across this i guess it doesn't matter there's a python library called plumbum and it's.

00:43 That spelled plumbum i have no idea where they came up with that name but it's a toolbox of goodies to do shell like things in python.

00:53 It says shell combinators and more i'm not sure the combinator is.

00:57 Oh there was that white combinator on back to the future other than that i don't know what a combination is like the pipes between things maybe perhaps anyway.

01:07 The model library and i'm read this is direct quote is never write shell scripts again.

01:13 And thus it attempts to mimic the shell syntax, oh, shell combinators is shell syntax, where it makes sense while keeping all the Pythonic and cross-platform goodiness of Python.

01:25 And it's kind of fun and it's one of those things, it's kind of cheating, actually, I think, but it's cool.

01:31 We have an example in the show notes, but there's a bunch of examples on their website, on the readme and stuff.

01:38 You can do things like chaining commands like with pipes, and there's a built-in grep and word count and head counts within this library.

01:47 So if you've got a bash shell script and somebody says, "Hey, you should convert that to Python." This would take you like five minutes to convert it to Python using this.

01:56 That's not necessarily a bad thing.

01:58 If you know how to transform something here, you can convert it right away.

02:04 Then maybe if you want to go figure out how to do that with other ways, You could, but for a lot of quick and dirty things, why not do something like this?

02:12 - It looks really cool.

02:13 Certainly writing Bash stuff, the more tests you have to do and the looping over things, it's just like, how do you do that in Bash again?

02:21 You know, it's just, it's not so nice.

02:23 But there's certainly things you can do in the shell that are painful in Python.

02:26 Show me the files here.

02:27 It's like, okay, well fine, we're gonna import OS and we're gonna do a lister and loop over that.

02:32 Right, like LS, right?

02:33 That's super easy.

02:34 And this kind of brings those things together.

02:36 It's really nice.

02:37 - Yeah, so I've got a couple things I'm gonna throw this out right away is we're converting from, on in Jenkins you can do shell commands within like the little command steps of Jenkins, but if you're doing pipelines on Windows you can't do Bash for some reason, or I can't figure out a way to do Bash, but I can do Python.

02:55 So I could write a little Python script to do the thing that I wanted to do in Bash and do it right there.

03:01 So I'll try that.

03:02 - Yeah, nice.

03:03 So this is a really cool project and certainly if you're thinking about some kind of bash script or something like that.

03:08 This is a really nice option.

03:10 - Maybe I should just try to use the Linux subsystem on Windows 10 instead of.

03:14 - Yeah, so if you have a problem with getting bash to work, it doesn't work on Windows, right?

03:19 But you can definitely bring in the Windows 10 Linux subsystem.

03:24 And obviously that's Windows 10.

03:26 I'm sure that it's available on the Windows Server equivalent of Windows 10, which I honestly don't even know what version that is, but there's probably a server equivalent.

03:36 that has the Linux subsystem as well.

03:38 People can throw that in the show comments if they want.

03:40 But there's an article by Marcus Sherman called the Windows 10 Linux subsystem for Python developers.

03:47 First of all, have you heard of this Windows 10 Linux subsystem?

03:51 Do you know what this is?

03:51 - Yeah, I've been trying to keep an eye on it and as they make fixes to it and add features, I've been trying some of these things out.

03:59 - Yeah, it's interesting.

04:00 So it's basically Linux embedded inside of Windows.

04:02 And you've always been able to run in Windows, like a VMware virtual machine or something and run say Ubuntu, but that's not what this is. It's not like a separate, entirely separate running VM, but it's like a little tiny micro VM type thing that is the command line shell for Ubuntu. So you can basically have Ubuntu commands and an Ubuntu terminal in your Windows. The idea is somebody says, "Hey, here is some library you want to use." And the way you get it is you compile it from source and run it, or you know, you need to have this other weird utility or type these commands, right? Like how often have you seen a tutorial that says, "Okay, Brian, the next step is to type Python 3 -m venv.env and then you say source.env bin activate." That's awesome, right? It works fine on your Mac. It works fine on my Mac. It works fine on my Linux server. Does it work fine on Windows? No, you have to use the scripts directory. Scripts directory, There is no Python 3, there is no source.

05:01 Like what is all this stuff, right?

05:02 It's like, why is it different?

05:04 And so the motivation that Marcus had for writing this is like, hey, if you're gonna learn Python and you're on Windows, you might consider using the Ubuntu subsystem because then all those commands that everybody tells you to do, they just work.

05:16 'Cause it says, hey, look. - Oh, that's a good idea.

05:18 - You could use, say, Anaconda, and you get all the tools, but you still can't type Python 3, you still can't type source.

05:25 Like all these things don't work unless you run Ubuntu for Windows.

05:28 So it's a really nice step-by-step way to go through it, specifically for setting up for Python development on Windows.

05:35 - Okay, cool, neat.

05:36 - Yeah, pretty sweet, right?

05:37 So you might say it's a little cheat sheet for getting Ubuntu working there, right?

05:42 - Yeah, hey, we're doing really good on the whole transition thing.

05:45 - Yeah, it's working.

05:47 - Yeah, we've got a cheat sheet on my next item.

05:50 I've been trying to do type hints a little bit more, especially, so we've got a lot of people at work and myself are using PyCharm. And the little pop up dial, I don't know what that complete drop down type dot, yeah, that all that stuff works really great. And you it also works better if you have type hints in your API is just two things. So I've been trying to do at least for the external functions, I've been trying to do type hints in there, but I forget some things.

06:19 So I ran across this type hints cheat sheet. And it's on the It's actually on the mypy documentation site.

06:26 But the things that, I mean, I remember some of the easy things, like how do you represent string and int and stuff like that.

06:33 But what about duck type stuff?

06:35 Like if I have a thing that acts like an array, but it might be a tuple or it might be a list or it might be something else that I just know that I need to be able to use the bracket index operator and find the length.

06:49 Well, that's a sequence for type hints.

06:51 But I don't always remember that if that's an iterator, iterable or sequence or things like that.

06:56 So those duct type things are what I'm using it for the most, but I have other people that I work with that are just sort of learning this type in thing.

07:04 So all of it's useful.

07:06 - Yeah, and it's not that long.

07:07 A scroll bar estimation is probably seven or eight pages.

07:10 Flip through that once and you pretty much have mastered the type ins.

07:13 There's a couple interesting things in here that I thought was nice.

07:17 Talking about adding type ins for asynchronous functions, So async def, the one that I had never seen was class level variables.

07:26 So class var looks pretty interesting.

07:29 Like it's not on the instance, but it's on the type.

07:31 Oh, interesting.

07:32 Right?

07:33 You can use class var annotation to declare a class variable.

07:36 I'd never done that.

07:37 I'm just, you know, and that's pretty interesting.

07:39 And then also specifying the type for, say, a generator or something that yields some kind of iterator.

07:46 It's pretty interesting.

07:47 There's also a generator, actual generator type declaration that takes three arguments that's not covered in here.

07:52 So that's also potentially worth noting.

07:55 But yeah, very cool stuff.

07:56 And I think this is a nice find.

07:58 Cool.

07:59 Nice.

08:00 Now, before we get on to the next thing, I want to tell you quickly about DigitalOcean.

08:02 Like I said, they're sponsoring the show, and they have lots of good reasons to go check them out.

08:07 Something that they just announced that's coming soon and is available for early access is Kubernetes.

08:13 So if you have some kind of site that you would like to run on a Kubernetes cluster, you can now go first visit pythonbytes.fm/digitalocean, create an account so you get the free $100 credit, and then go to digitalocean.com/products/kubernetes.

08:28 And you can sign up for early access to check that out.

08:31 So then you can submit containers to run on the Kubernetes cluster and have simple zero downtime deployments.

08:39 That's actually very, very cool.

08:40 Yeah, I'm pretty excited about that coming along.

08:43 going to be fun. So every now and then we cover these sort of higher level topics a little softer. Here's one that tries to look a little bit farther in the future and I'm just gonna put these out there and then I'll let you give me your... you react to this article. Okay so the overall theme here is that Python is driving the creation and foundation of new languages. Okay so this was an article and it says here are five predictions for what programming will look like in 10 years. Programming will be, okay, so number one, programming will be more abstract. When I first read that I'm like, oh please don't tell me it's drag and drop. QML again or something like that, right? But no, they say that trends like serverless technology, containers, we just talked about Kubernetes, and low-code platforms suggest that developers may be able to work at higher level of abstractions in the future, not thinking about servers for example. And that sounds reasonable. Yeah, to some extent, yeah. Yeah, potentially. AI will become a a part of every developer's toolkit, but it won't replace them.

09:41 What do you think?

09:42 - I don't buy that actually, but okay.

09:44 - Get some comment I could say to some of the voice assistants, but I'm pretty sure I'll set off like thousands of them, so I won't do it.

09:50 All right, a universal programming language will arise.

09:54 - Well, Python, it's already arisen.

09:56 - So yeah, so the reason this whole article was pretty interesting is it has a pretty strong Python influence.

10:03 So for example, at the beginning it says, "Look, just in the last few years, some languages have risen and some have fallen and like the have risen links to an interesting article about Python, have fallen links to an interesting one about Ruby, for example.

10:15 And then under this section, there's a nice quote that says, "Python may be remembered as being the great-great-great grandmother of languages of the languages of the future, which underneath the hood may look like English, but are actually far easier to use." Okay. Yeah.

10:29 Okay.

10:30 Ready for my reaction yet or you got more?

10:31 I'm ready. Bring it.

10:32 I think some of the things are, one of the jokes about Python sometimes is that it's a, it's runnable pseudocode.

10:39 I don't like it.

10:40 I don't actually want it to get closer to English because English has so many subtleties and weird things that you can do that have implied meaning that the closer we get to the actual English language, actually the harder it is to actually debug something.

10:57 So having it not be that close, I think is better because it's less up for interpretation.

11:05 >> Right.

11:06 Please read that sentence.

11:07 The people over there have already read the red sign.

11:08 You know, things like that.

11:12 I'm not so sure that a universal language will arise either.

11:15 There's always something you may want to take most advantage of and by doing so, you make it less good for other things.

11:22 For example, look at like, say, the data science tool set.

11:27 better working with sets of data than individual things.

11:31 I don't know, it focuses on one thing, and so then other things become less easy with it.

11:36 All right, so I don't know.

11:38 One of the changes which is nice is that the languages are not being developed in the vacuum that they used to be.

11:45 They're learning from each other.

11:46 Yeah, that's for sure.

11:47 And we're getting the mega cool feature in one language that we would like to have in another.

11:53 We're already seeing that.

11:53 Python's taking some features from other languages and pulling it in.

11:57 Other features are taking cool languages.

11:59 And now if I've heard from a lot of people that hardly any other languages have good testing tools like pytest.

12:07 Specifically, they don't have pytest for other languages.

12:10 And that would be cool if we could have some better testing tools in other languages.

12:14 So yeah, I mean, there's certainly examples of that, like Swift, Apple's Swift is very much Python inspired.

12:20 you see like the optional, the null coalescing operator being moved towards Python and 3.8 potentially, things like that.

12:27 So I agree, I definitely see it as a blending, I don't know if there'll be a single one.

12:31 So alright, final two, every developer will need to work with data.

12:35 I think that they're doing that now, right?

12:37 Yeah, I think that's already, we always have.

12:40 Yeah, and then programming will become a core tenant of the education system, like reading and writing.

12:45 I believe that.

12:45 I do too.

12:46 It isn't necessarily like reading and writing. I think it's more like learning biology and basic chemistry.

12:53 It's not that you actually need it every day, but it's good that most people kind of understand how it sort of works.

12:58 Yeah, I'm totally with you. And the thing I think it will eject from the education system is geometry.

13:04 I feel like the reason that geometry is taught in middle school and high school is so that critical thinking and proof type of logical thought can be taught.

13:13 hot. Like you don't really need to prove this thing about isosceles triangles.

13:17 Like that doesn't help you in life. But the thought process does. And I feel like programming, you have the same type of thought processes, but you get a skill not just a grade. Yeah, my prediction. That's interesting. Yeah. Yeah, we'll see about that. All right, so another one on async.io, something I've been digging into a ton lately. Yeah, I wasn't even aware that this was a thing going on. But apparently the standard library async.io documentation was completely rewritten from scratch recently.

13:47 That's awesome. That's big news.

13:48 Yeah, it even says it in the tweet announcement. This is big news.

13:52 With like two flames on the side.

13:54 So I haven't actually read through this a whole bunch, but it does look like there's quite a bit of documentation there.

14:00 So that's neat.

14:01 That's really cool.

14:01 And it says they're not done.

14:03 So there's a comment that there's, this is just the beginning, that there's, they're going to add some tutorials for high level concepts and APIs, and then they're also going to keep going because apparently there's some new things planned for 3.8.

14:17 Yeah, that's awesome. You highlight some of the things coming for async.io itself, like the library and the capabilities async and await are getting better, right?

14:24 Yeah, and I think this sort of talks to the importance of async in the future.

14:28 If not only are people still working on making, improving the async story within Python, but they're also trying to improve the documentation to make sure that it's usable, which I'm glad to see that sort of documentation going side by side with new concepts.

14:45 That's a good thing.

14:46 But that kind of highlights the importance of async going forward.

14:49 Yeah, I think async is just becoming increasingly important, and I'm really glad to see it really gaining some momentum because if you look at apps written with and without async in a library that can take advantage of it, it's like night and day. It's ridiculous.

15:03 I think that, like you said, again, it's a different concept sort of thing.

15:07 You can think in higher level concepts and break problems up into the more logical breaking points.

15:12 Right. You don't have to think about threads and processes and coordination and all that.

15:16 You just say, "I'm going to do this part, then I'll wait, then I'll do that part, then I'll wait, then I'll do that part." And then, you know, that's sort of that higher level abstraction.

15:23 Yeah.

15:23 You want to get caught up on all the places that Python is headed?

15:27 All the directions? All the threads?

15:28 Yeah, definitely.

15:30 So there was the 2018 Python Language Summit.

15:34 Okay, that's where all the core developers get together and they talk about what they're doing.

15:39 They do proposals to each other like, "Hey, I think we should focus on this," or "We need to address that," and so on.

15:45 And there's some really interesting items.

15:47 And on lwn.net, which is a pretty interesting site, they've got a lot of great stuff, mostly focused on Linux.

15:55 It's kind of like the Craigslist of Linux news or something.

15:58 I don't know.

15:59 design but basically this is a meta article about the Python language summit this year and it lists off a whole bunch of sessions each of which are covered in detail in another article. So what I'm going to do is cover the high level bits of each one of these main sessions. So the first one is could we have sub-interpreter support for Python?

16:19 So we were just talking about async io and stuff. One of the main problems, I don't know if I'd call it really a problem because there's a lot of ways around it actually, but conceptions is that Python Python's not great for threading, specifically around taking advantage of multiple cores for CPU stuff, because of the gill.

16:34 It can have 100 threads and only one will run at a time if it's pure Python because of the gill.

16:39 So the suggestion is, could we take this feature, which is apparently already in Python, called subinterpreter support, to create lightweight subprocesses that run within the same process?

16:53 will allow multiple Python interpreters per process.

16:58 And there's potential for zero copy data sharing between them and things like that, which is pretty cool.

17:03 That's interesting.

17:04 It might be interesting even for versioning, right?

17:05 Like this library requires this version where that library requires that version.

17:08 Well, you can run like maybe multiple subinterpreters.

17:11 So I don't know.

17:12 That's a whole different angle.

17:13 And it wasn't part of this presentation.

17:15 But they say the problem is that subinterpreters currently share the gill.

17:20 So the potential work is, could we make them not share the GIL so they actually can take advantage of multiple cores?

17:27 It's becoming a thing.

17:28 So my MacBook, my new MacBook here has 12 cores as far as the OS sees it.

17:33 And if I write Python code and it takes full advantage of all the processor that it can and single thread it, it's only 8.3% of the capacity of the CPU.

17:42 That's a lot less than 100%.

17:44 So having features like this to let you do more computation would be great.

17:48 All right, so I don't want to go too deep in these because it'll like make this an hour-long show so I'll try to go a little quicker.

17:54 So the next one is modifying the Python object model, looking at CPython's structure.

17:59 So Carl Shapiro from Instagram talked about how they might rework the way the interpreter interacts with classes for better performance and memory and stuff because Instagram is all about that.

18:12 It's one of the interesting things in this article is that there was some controversy around like the presentation and some other stuff so I'll let you read about it. I won't bring it up here but it's worth looking at. We just talked about the gil for parallelism and Larry Hastings has been on and off working on this thing called the gilectomy, the removal of the gil. And the gil basically is a thread protection around allocation in Python which means you don't have to like take a bunch of fine-grained locks when you're allocating new objects but because of that it means only one instruction can run at a time.

18:44 So could we take that out and have a Python that does like true parallelism?

18:49 Basically the update is not much has happened.

18:51 So for better or worse, Marietta talked about using GitHub issues for Python.

18:57 I didn't realize this wasn't already happening, but apparently it's not.

18:59 Apparently there's another site that's currently being used and trying to move over to GitHub issues.

19:04 That's pretty cool.

19:05 Lucas talked about shortening the Python release cycle.

19:08 So right now it's on an 18 month release cycle.

19:13 So in 18 months from whenever 3.7 was out, 3.8 will be out.

19:16 Can we make that yearly? It's possibly the conversation. So you can read that.

19:19 One that you might find interesting is unplugging old batteries.

19:22 So unplugging old batteries, there's like, there's like encoding libraries for like formats that like predate MIME and other weird type of things that are in there that nobody likely uses anymore. So what is the process for taking stuff out of the standard library?

19:38 There's a process for getting in, but how do you get it out?

19:40 Oh, that's interesting. Yeah, a lot of things could probably be not just completely eliminated, but moved to, like, just a package or something.

19:48 Exactly. Like, this is now out. But if you need it back, you can pip install it separately. But your job is to maintain it. Like, we're not shipping it anymore. Something to that effect. It's kind of cool.

19:56 Yeah.

19:57 They talked about Linux distributions and Python 2. With Python 2 coming to end of life, what is the process for, like, basically getting those out of the Linux systems that they ship with? And how do we do that?

20:09 You talked about Python's static typing.

20:12 So there's an update on that, mostly focused on stub files.

20:17 Have you heard of stub files?

20:18 - Yeah.

20:19 - It's like the dot, dot, dot, right?

20:20 I've looked at them and they basically are the method signature and then dot, dot, dot.

20:25 And they're not actually the implementation.

20:27 They're just saying here is the actual shape of this method.

20:32 And so what you do is they get imported alongside of your code by things like mypy.

20:38 So they're kept in this thing called the typeshed, which is a place for third party libraries to be in there.

20:44 So you can look through there and see things like what type of stuff, like the context variable in what is its type definition, for example.

20:54 So there's a bunch of things with dot dot dot.

20:57 They're just like empty, not implemented sort of structures.

21:01 And so this is where a lot of the third party stuff and the standard library goes.

21:06 But they're saying, look, a lot of packages are not putting things here, like namely things like Django and SQLAlchemy.

21:13 So there's a proposal of finding a way to bind the type information to the package and not to the central location so that package maintainers can ship those stubs along with their libraries.

21:25 Yeah, that would make more sense, or at least it would make some sense.

21:28 Yeah, like it'd be easier because then you don't have to say like do a PR to some other repo, like you just put it along with your library and it's in pip.

21:34 Yeah.

21:35 So Python virtual environments, there's some debate about whether they're useful and what we might do instead, primarily around like, if you're trying to teach Python, you shouldn't have to start out with a 20 minute conversation of how to do virtual environments, both on Linux, Windows, and macOS.

21:49 And then you can actually talk about hello world, but just how do we just do that?

21:54 So an interesting debate there.

21:57 There was some conversation around the whole new decision decision making process now that Guido stepped down.

22:04 Another one about getting along in the Python community, trying to make things like the dev mailer list be more interesting and welcoming as well.

22:12 Also, finally, mentoring and diversity for Python with Marietta and Victor Stinner as well, two separate presentations in that general area.

22:20 So there's every single one of these things I've talked about, there's an article about it and more references.

22:24 And so if you want to dive into it, it's like, it'll keep you busy for an afternoon.

22:28 - Okay, one of the things that you wrote down but we didn't talk about was TK enter.

22:33 Oh, so the one about getting along and being more civil on dev was somebody complaining that TK Enter is so badly out of date that it should be removed from Python, but it's shipped with Python, which kind of brings us back to how do we unplug old batteries?

22:46 Because if people don't maintain it and it doesn't work for anyone, then why would TK Enter be there?

22:51 So there's, we might get back on another GUI kick if we go down that too far.

22:57 Okay.

22:58 Anyway, that's what that was about.

22:59 the sort of rudeness on the mailing list was focused around TK enter.

23:03 Okay.

23:04 And whether it needs to be upgraded, removed, whatever.

23:06 Well, that is it for the Python language summit, but I thought that was super interesting.

23:10 And there's just so many looks at where people are putting their effort.

23:13 I mean, this is where the core developers are focusing their time.

23:16 So I think it's definitely worth paying attention to.

23:18 Yeah, definitely.

23:19 Cool.

23:20 All right, you got anything else you want to share with folks while we're here?

23:22 Yeah, one thing.

23:23 I noticed this from, I'm going to get his name wrong.

23:26 Anthony Sadio, code with Anthony on Twitter, mentioned that Precommit had a huge jump in downloads on July 30th.

23:37 I first assumed that it was because we covered it or something, but apparently it didn't line up with us covering it.

23:43 You should have covered it earlier, could have gotten credit, but no.

23:46 But I looked at other packages and there is a weird jump in like almost all packages downloads starting in at the end of July.

23:57 I don't have any news around that just that's weird and I wonder what's going on.

24:01 You know I wonder if that has to do with when the new PyPI launched.

24:06 Oh yeah I wonder and it's almost coincident with the pip 18 as well.

24:11 The new PyPI launched in April so yeah it could be with pip 18.

24:15 Who knows I bet it's some low-level infrastructure thing like caching got expired and everything that had cached it everywhere got a new one or something.

24:22 Yeah, maybe they changed the way they were caching it or something.

24:25 I do remember seeing that from pip that every now and then, like if you run a sufficiently old pip, it'll say that it's offline cache is not compatible and it'll redownload.

24:35 So I'm wondering if in the reverse direction, when a new pip came out, that may happen.

24:39 So I bring that up so that if anybody knows what's going on, they can get a hold of us and we can find out.

24:44 Yeah, throw it in the show notes, pythonbytes.fm/96.

24:47 Yeah, and that's one of the things that I love about this is because we can talk about things that we don't quite know about and people will correct us.

24:53 They're generally pretty nice about it too, so thank you for that.

24:56 Yeah, so one of the things that somebody mentioned, we've talked about PyCuda.

25:01 Cood-pie.

25:01 Did I get that right?

25:02 I think it's cood-pie.

25:03 Yeah.

25:04 Coo-pie.

25:04 Yeah, coo-pie.

25:05 Coo-pie.

25:05 We were guessing that maybe if you had a video card on your laptop, maybe you could use it, but we were corrected that it would have to be an Nvidia card because Cuda only runs on Nvidia.

25:17 Yeah, so apparently CUDA is a NVIDIA thing, which I didn't realize. I thought it was just a graphics card standard, but no, it's an NVIDIA thing.

25:23 So, you, this is all triggered by your question, could I do this on my MacBook or on my laptop?

25:29 If you have like a Windows or Linux laptop that has an NVIDIA card, yes. Otherwise, no. Apparently, it's the answer.

25:35 So a couple people wrote us that, wrote us and communicated that to us, so thank you all for that.

25:40 I guess if you're on a MacBook, you could get an external.

25:43 On the new ones you can do external GPUs and you could get an NVIDIA one there, but even the one sold by Apple is actually a Radeon, so it doesn't help you.

25:51 Okay.

25:52 So, anyway, just thanks for the clarification.

25:55 Yeah, do you have anything else to add?

25:56 Nothing else. Not right now. I have some good news next week I'm going to share, but right now nothing to say.

26:02 All right, well thanks a lot.

26:03 Just working away on projects. Yeah, thank you. Great to chat with you as always.

26:06 Yeah.

26:07 Thank you for listening to Python Bytes. Follow the show on Twitter via @PythonBytes.

26:12 That's Python Bytes as in B-Y-T-E-S.

26:16 And get the full show notes at PythonBytes.fm.

26:19 If you have a news item you want featured, just visit PythonBytes.fm and send it our way.

26:24 We're always on the lookout for sharing something cool.

26:26 On behalf of myself and Brian Aukin, this is Michael Kennedy.

26:29 Thank you for listening and sharing this podcast with your friends and colleagues.

Back to show page