Transcript #74: Contributing to Open Source effectively
Return to episode page view on github00:00 Hello and welcome to Python Bytes, where we deliver Python news and headlines directly to your earbuds.
00:05 This is episode 74, recorded on April 17, 2018.
00:10 I'm Michael Kennedy.
00:11 And I'm Brian Okken.
00:12 And I'm Matt Harrison.
00:13 Yeah, that's right.
00:14 We've got a special guest here on the show.
00:17 So Brian and I decided to invite Matt Harrison to mix things up a little bit and bring a slightly different perspective.
00:22 And we decided we're going to try this little experiment from time to time, you know, once a month, once every six weeks, something like that.
00:28 So, Matt, welcome to the show.
00:30 Thanks.
00:31 Thanks for having me.
00:31 Good to be here.
00:32 Good to have you here.
00:33 So before we get into the topics, I just want to say thank you to Datadog.
00:36 They're sponsoring this episode.
00:37 Check them out at pythonbytes.fm/Datadog.
00:41 I'll tell you more about them later.
00:42 Brian, you've been running your own open source project lately, and it's been fun, right?
00:47 Yeah, I started a little project.
00:48 I called it Cards.
00:49 But the intent was to – it's on GitHub.
00:52 And the intent is to talk about, like, how I'm going to go about testing it using all the – what I think of as good test methodologies.
01:01 But doing it in the open on an open source project, I'm getting contributors already, which is really cool.
01:06 That's awesome.
01:07 I don't really know the conventions.
01:08 And even though I've been programming for decades, I'm kind of new to the – actually contributing to open source.
01:14 Well, and it's different on GitHub than it was, say, in Subversion or something like that, right?
01:19 There's the whole Git flow and PRs and that whole thing, right?
01:22 Yeah, and how to deal with, like – how to deal with branching with – branching and forking with GitHub versus doing something out in the open on GitHub is one thing.
01:32 But actually running it like a normal open source project is completely different.
01:37 So I had a – actually, Anthony Shaw did a pull request on Cards, and he did a really good job on it.
01:45 And I was – one of the things is he started it with a WIP for a work in progress.
01:49 And I didn't know that was a convention already.
01:51 So I looked around, and there's some – if people are new to this and want to learn more, I'm sure everybody out there already knows about open source stuff.
02:00 But anyway.
02:01 I would not make that assumption.
02:02 I definitely would.
02:04 I mean, it feels that way, but I think it's more of a dark matter sort of experience where, like, you see the stuff that people are doing.
02:13 But that doesn't mean everyone is participating.
02:15 And many people, I think, are just wanting to get into it.
02:18 What do you think, Matt?
02:19 I've been using open source since the mailing list days, and you had to talk over the mailing list.
02:24 And so GitHub, when it first came out, was sort of a big change for me.
02:28 And I think a lot of people use GitHub as just, I'm going to throw my source over the fence and see what happens to it, rather than maintaining it as a real open source project and trying to include community and get contributions.
02:39 So I'm curious to see how this works.
02:42 And I think, like Michael said, don't make the assumption that everyone knows how to do these things, even though some people are doing it.
02:49 There's certainly a lot of people who can learn from this.
02:51 There's a couple of things I wanted to throw out.
02:53 This is from 2015 already, but it's an article called How to Write the Perfect Pull Request.
02:58 And it kind of talks about the philosophy sort of both with approaching the pull request when you're first getting started.
03:05 And it even talks about the WIP trick to tell the person that owns the repo, you're not done with it.
03:11 You just kind of like early feedback on it.
03:12 And then there's some advice on offering feedback to pull request submitters and also responding to that feedback as the submitter as well.
03:23 It's a short read, but there's some good tips there.
03:26 And then I'm also really excited about VM's new book coming out from Pragmatic called Forge Your Future with Open Source.
03:34 And it includes things like how to deal with pull requests and everything.
03:37 That sounds like such an interesting book.
03:39 I love it.
03:39 And I just like to say, like, I think getting using open source and getting involved for someone who wants to get a break into learning Python or learning a library or even getting a job.
03:51 That's an awesome way to do it.
03:53 I agree.
03:54 And one of the problems people run into is they work in a place that doesn't use Python.
03:59 And so they don't have a place to actually practice Python outside of just like toy things.
04:04 So contributing to open source lets you make a meaningful contribution, even though maybe you're a Java or .NET shop and they're like Python?
04:11 No.
04:12 Or yeah, they might even be using Subversion or some other source control.
04:16 Absolutely.
04:17 Cool.
04:18 This is a good one.
04:18 This is a good one, Brian.
04:19 So, Matt, you and I both do in-person training periodically.
04:23 And I just did a class last week, I guess, a short class.
04:27 And it was a lot of folks coming from a traditional sort of MATLAB, Mathematica background and moving into things like Jupyter.
04:34 And I think that this might be a trend.
04:36 What do you think?
04:37 Yeah, I think we're seeing Jupyter changing from early adopter to sort of normalcy.
04:43 I found a thing going around Twitter.
04:45 Paul Romer, who's an economy professor at NYU, tweeted about his experience with Mathematica and Jupyter.
04:53 And he referenced an article in The Atlantic about both of those products, Mathematica and Jupyter.
05:00 And for me, like I said, I've been involved with open source for a long time.
05:04 You don't often see stuff in The Atlantic or professors, economy professors.
05:08 This isn't a computer science professor.
05:10 This is an economy professor posting about Python and Jupyter.
05:14 So, really cool stuff there.
05:16 This is such an interesting find.
05:18 And if you open, people should open up the Atlantic link that you're linking to here.
05:24 Because, wow, that's a pretty provocative picture.
05:26 There's like a formal paper.
05:29 It says the scientific paper is obsolete.
05:31 And there's like a paper, like an academic paper, that's literally on fire.
05:36 Like in an animated way, like full screen.
05:38 It's crazy.
05:38 Yeah, and it makes reference to the discovery of gravitational waves and how there was a paper on that.
05:45 But they also, along with that, published a Jupyter notebook where you could go out on your own.
05:50 And you could look at their code, look at their data.
05:53 And it had embedded text in it as well and basically discover gravitational waves or go through the same sequence and reproduce their science.
06:02 So, I thought that was pretty cool.
06:03 A quote from Mr. Romer.
06:06 He says that Jupyter is the new open source alternative to Mathematica that is well on its way to becoming the standard for exchanging research results.
06:13 I agree.
06:14 I think academics has been too dependent on these couple of big, really expensive lock-in type of things like Mathematica and MATLAB.
06:23 I'm also thinking of journals and stuff like that.
06:25 This sort of open source paper in the form of Jupyter kind of touches on both of those.
06:29 Brian, what do you think?
06:29 I'm actually really excited about all that.
06:31 I was just listening to a topic not too long ago about how the – actually, it was one of your podcasts about the academic journals that are – a lot of times nobody actually follows the steps along.
06:42 But having the code out on Jupyter notebooks just allows everybody to go and follow along right there.
06:48 One of the main points of these articles isn't that there's a notebook per se, but the compelling reason for using Python and Jupyter is not necessarily that the technology is better, but that there's a huge community around it.
07:02 So, you know, they make the argument that the Wolfram notebook might be prettier or whatnot, but you have so many people who are contributing to these open source projects.
07:12 You've got Matplotlib for graphics, SymPy for symbolic math, NumPy, SciPy, Pandas, NLTK.
07:19 And, you know, if you look at PyPI, there's 135,000 packages last week on that, and it's really hard to compete with that.
07:28 That's super compelling.
07:29 So, really cool.
07:30 Yeah, it is super compelling.
07:31 So, speaking of community, Brian, you know I love to, like, pull on the Stack Overflow developer survey and, like, try to dig out results from the community, right?
07:40 Yes.
07:40 Yeah, that's always fun.
07:42 So, there's another one that just came out that gives us a different perspective and also is more Python-focused than that one, right?
07:50 That's, like, broad software development.
07:52 So, JetBrains, the PyCharm team, teamed up with the PSF just at the end of last year to do a Python developer survey.
08:00 And so, the thing I'm linking to is Python developer survey 2017 results, but it's, like, December, right?
08:06 So, it's pretty relevant still.
08:08 It's pretty fresh.
08:09 They were just talking about it on their blog.
08:11 And so, this is a really nice piece of sort of almost journalism around data science, I think.
08:17 It's actually, they've really written it up nice.
08:19 They show you graphs, and they're like, here's the main takeaway from this section.
08:23 Here's the main takeaway from that section.
08:24 So, how about I share some takeaways with you?
08:26 Yes.
08:27 Yeah.
08:28 All right.
08:28 So, the first one is, says, of the people that they interviewed.
08:32 Now, this is obviously a self-selecting crowd.
08:37 But the question was, you're obviously doing Python.
08:39 Is this your main language or a secondary language?
08:42 And they said 80% of the people are, Python is their main language.
08:46 That was pretty cool.
08:47 They said data analysis is actually just as popular as web development, which is pretty cool.
08:55 So, there's basically as many Python web developers as there are data scientists.
08:59 Does that surprise either of you?
09:00 To me, Python felt like a web thing for most folks.
09:04 Yeah.
09:04 I mean, recently, it wouldn't surprise me.
09:06 But, you know, if you would have said that two years ago, it probably wasn't the case two years ago.
09:10 But now, yeah, it's not surprising to me.
09:12 Yeah.
09:13 They also talk about the growth of Python.
09:16 And Brian and I, you and I, we've touched on this a few times.
09:18 But they're also confirming, like, we think that massive hockey stick growth is largely data science people coming in.
09:24 Yeah, it could be.
09:25 There's, I think there's a lot of room to grow.
09:26 There's a lot of people who are using Excel and some of these tools that you mentioned who probably want to migrate to something like Python for the libraries and machine learning capabilities.
09:36 Yeah.
09:36 Another interesting one was Python versus legacy Python.
09:40 So, Python is at 75% usage among this group and 25% for Python 2.
09:48 And if you look at the curve, that's, like, increasing in time, like, the rate at which people are moving to Python 3.
09:54 So, that's really cool.
09:56 Yeah, that's cool.
09:57 Yeah, you wonder how much self-selecting is there, right?
10:00 The legacy laggards didn't want to participate in this.
10:03 That's right.
10:04 I don't need no stick-in surveys.
10:05 I learned everything about Python I need to know in 2008.
10:08 Okay.
10:09 So, they also talked about where code runs, where people run their Python code.
10:13 And this is, I don't think it clues, like, the hosted notebook type stuff.
10:17 So, probably not that.
10:18 But 67% AWS.
10:20 Brian, does that surprise you?
10:21 I'm going to plead.
10:22 I'm not in the field, in the web sort of space to know, really, where it's running.
10:29 My basis for sort of judging the use of AWS compared to other platforms is when AWS goes down, what parts of the internet are no longer accessible?
10:39 And they're pretty broad.
10:40 Yeah, I would think that it'd actually be a little bit higher than that.
10:43 The ones that surprised me was you've got Google App Engine at 29, Heroku at 26, Digital Ocean at 23.
10:50 And the last one they say is Microsoft Azure at 16.
10:54 And I think that 16 is probably going to change a little bit.
10:57 They've been doing a lot of hiring in the Python space and getting some prominent Python people.
11:01 So, there's a big push from Microsoft on that.
11:04 They're definitely focused on Python in a lot of important ways.
11:07 They now have Azure Notebooks.
11:09 They have Brett Cannon, Steve Dower, both Python Core devs, working there.
11:14 They brought the guy who did the Python extension for Visual Studio Code in-house.
11:18 Like, they're doing a bunch of cool stuff.
11:20 All right, so a few more takeaways.
11:21 Team size, right?
11:23 Like, you think of how big of a group do you, you know, like how large of a team do you work on?
11:29 And if you think about, like, one of the advantages of Python is you don't need a large set of people to build something interesting.
11:34 And I think that's reflected here.
11:36 So, it says, like, team size, 2 to 7 people, 75%, 74% of the respondents are in that 2 to 7 group.
11:43 And then 8 to 12 is 16.
11:45 And then, basically, above that, above 12 people, all the way up to, like, 40 or larger, is 9% of the balance, basically.
11:54 So, really small teams.
11:55 And then operating systems, Brian, you touched on this a lot.
11:58 49% of the people are still using, are currently using Windows as their OS.
12:03 Then 19% for Linux, 15% for Mac.
12:06 And, like you said before, like, Windows often gets the short end of the stick and sort of testing and examples and stuff.
12:12 But it probably shouldn't.
12:13 Yeah, one of the things I want to go back to is the cloud platforms that we talked about.
12:18 One of the things that's interesting to there is that, clearly, some people are running on multiple platforms because that's over 100%.
12:26 Yeah, that's interesting.
12:27 Like, I could tell you for sure that, like, if somebody asked me, which of these platforms do you use, I would definitely check the DigitalOcean and AWS boxes.
12:34 Okay.
12:35 Because, like, for example, the main server for our podcast and the database server runs on DigitalOcean droplets.
12:42 But when you interact with it and you get, like, say, an email, especially around the training stuff, that goes through Amazon simple email notification service and things like that.
12:51 So, like, there's this blend of them.
12:53 Yeah, I'm similar.
12:54 I've done Heroku and DigitalOcean and both had stuff in S3 as well.
12:57 So, it's not an either or.
13:00 One of the things I thought was interesting was the operating systems.
13:03 I mean, like you said, Windows tends to get, you know, people have something in their heart against it or whatnot.
13:10 But I was surprised that Mac was so low on this.
13:13 Yeah.
13:14 Interesting.
13:14 I wouldn't have thought that at all.
13:16 But you go to the, I'm telling you, Dark Matter developers, that's what it is.
13:21 Yeah.
13:22 It's interesting.
13:23 I think the story on Windows is going to get better.
13:26 I believe the new version of Python is going to use MS Build and not Visual Studio 2008 for its compilation stuff during install,
13:37 which means, like, modern versions of Windows will be able to install stuff without, like, installing a 2008 version of Visual Studio, which will be real nice.
13:45 All right.
13:45 So, before we get to the next one, I want to just tell you both a little bit about Datadog.
13:50 So, speaking of stuff hosted in the clouds and spanning multiple machines and things like that, Datadog is a monitoring solution that provides visibility and tracks down issues with distributed systems involving Python applications.
14:04 So, within just a few minutes, you can find bottlenecks in your code by exploring graphs and rich dashboards.
14:09 And you can visualize your whole performance across all of your apps, which, when you're doing distributed programming or distributed apps, microservice type things, that's a huge deal.
14:19 And you can go to pythonbytes.fm/datadog, do a quick little trial there, and you'll get a free Datadog t-shirt, which is pretty cute.
14:28 So, check them out and let them know you appreciate them supporting the show.
14:31 All right, Brian.
14:32 I'm a big fan of databases, especially shiny new ones.
14:35 You've got a really new one yet.
14:37 Like, I can't even get this one yet, but it's still pretty cool.
14:39 Yeah, you can't get it.
14:40 But one of our listeners, Arash, I think that's his name.
14:43 Anyway, he let us know about EdgeDB, and EdgeDB has a blog post up.
14:50 It says, EdgeDB, a new beginning.
14:52 And at first, I thought, yeah, okay, we'll keep an eye on this, and maybe we'll cover it later when we can actually play with it.
14:59 Because it's a new database that's not available to use yet.
15:02 However, it's going to be open source.
15:05 And the reason why I brought it up now is because it's coming from some fairly interesting people.
15:10 It has some pretty powerful Python origins, right?
15:13 Yeah.
15:14 Well, so, like, for instance, Elvis and Yuri, and I'm not going to try to pronounce their last names, or they will flame me.
15:21 Part of this, and they're the people that brought us AsyncIO and UVloop.
15:25 So, that's pretty impressive.
15:27 That's very impressive.
15:27 One of the things that's interesting is looking at the kind of code that you get with this.
15:32 So, they're trying to attack the problem they're addressing is that document databases have some issues with just scalability.
15:41 After your project gets larger, the schemaless part of it sometimes can be hard to deal with.
15:49 A lot of people deal with it fine, but they see it as part of a problem.
15:52 And relational databases are growing a lot, and Postgres, for instance, is keeping up to date.
15:58 But the interface, how you interact with the database, the schemas and the underlying API to the database, hasn't changed much in a long time.
16:07 So, they're trying to change that.
16:09 And I forget what they call it, an object relational?
16:13 They call it an object database.
16:15 Object relational database.
16:17 Yeah, yeah, yeah.
16:18 Yeah, not like the traditional ones, they say, from the 80s.
16:21 Yeah, so one of the things to look at, if you're going to look at anything, is to go to the link and look at the example.
16:28 They have a new query language called EdgeQL.
16:30 So, they have a different way to write a schema that's fairly, doesn't really look like Python, but it's type-based, and it's fairly expressive.
16:40 It's pretty interesting.
16:41 So, instead of saying, like, let's have a class and map that to the database, like, say, SQLAlchemy or MongoEngine might,
16:48 they said, we're going to define our own data definition language, our own DSL, but it's really incredibly simple.
16:55 Like, doing the relationships with cascading this and that in SQLAlchemy, I always get that wrong.
17:01 You know, I have to look it up.
17:03 And this is like, you want a foreign key relationship, you say link assignees, goes to a user definition, and the cardinality is double star,
17:10 so I'm guessing multiple, many-to-many sort of thing.
17:14 And that's on, like, incredibly short there.
17:17 So, my first impression was, like, really a new schema definition language, a new query language.
17:23 Like, seriously, like, it's just like, okay, well, I'm tired of SQL, and I'm tired of the other ways of programming.
17:29 So, we're going to invent, like, another thing that people are going to get tired of.
17:31 But it's starting to grow on me.
17:33 Matt, what do you think about this?
17:34 Whenever you say, I'm going to invent something that's going to replace SQL, I think you hear a million developers cringe because they all know SQL, right?
17:43 But I think if you can get the five-minute out-of-the-box presentation where it's like, this is a compelling reason to use it.
17:50 And, you know, everyone, or at least most Python people I know, want to use, like, an ORM and interact with the database that way.
17:57 But there is this impedance mismatch with those.
17:59 So, if you can nail that down and have, like, a really smooth five-minute out-of-the-box experience with this, I think you could get a lot of people interested in them.
18:08 Yeah, it's pretty interesting.
18:09 I'm glad you brought it, Brian.
18:11 Thanks.
18:11 All right.
18:12 Matt, so you're a fan of the Wizard of the Oz is what I'm to draw from this next one.
18:16 Yeah, yeah.
18:17 Follow the yellow brick road.
18:18 So, I've been, I do corporate training and I do consulting.
18:21 And one of the things that I do when I'm doing data stuff is visualization.
18:26 Visualization is pretty important.
18:27 I mean, I've literally found bugs by visualizing something that we couldn't have found just by looking at the data necessarily.
18:35 And so, visualization is also important in the evaluation of machine learning projects.
18:39 And one of the projects that I've been liking and using recently is a project called Yellow Brick.
18:44 So, I guess this will take you to the Wizard of Oz if you follow it.
18:47 It's not a new project necessarily, but it's a project that's alive and going and being worked on still.
18:55 And what it does is it offers visualizations for various machine learning algorithms.
18:59 So, if you use a tool like Scikit-learn, you can go to their website and they'll have all these visualizations up there.
19:05 But those aren't included in the library for Scikit-learn.
19:08 You either need to...
19:09 You've got to go create them yourself, right?
19:11 Yeah.
19:11 You've got to either copy and paste their code or go find some Stack Overflow.
19:15 So, what I've been doing...
19:17 I mean, I have a project on my GitHub, MLViz, that I just have my own...
19:21 Here's the visualizations that I commonly use.
19:24 And then I use my little library.
19:25 But I'm looking to replace it with this.
19:28 And I've been using this for some of my training as well recently.
19:30 So, it's got visualizations for classification, regression, clustering, and text.
19:36 One of the cool things about it is if you're familiar with SK-learn or Scikit-learn is that it has a similar API to that.
19:44 So, there's a fit.
19:45 You can fit your visualization.
19:46 You can transform it.
19:47 And then you call this method called POOF.
19:49 And that will pull up a map plotlet for your POOF.
19:52 That's the magic method that they have.
19:54 How do you spell POOF?
19:55 P-U-F-F?
19:55 P-O-O-F.
19:57 POOF.
19:57 Yeah, POOF.
19:59 Gotcha.
19:59 Yeah.
20:00 Perfect.
20:01 Love it.
20:01 So, just a nice little library to, you know, one of those things that can be annoying or that you always go and copy and paste that code.
20:09 And if you can just pip install this and use it.
20:11 And it has a great interface.
20:12 It makes your life a little bit easier.
20:14 Yeah, absolutely.
20:15 So, Brian, the next one, the last one that I want to cover, comes from the whole Alexa thing.
20:22 We've had a couple of people write us about interesting things with, like, say, Flask Ask and Alexa skills, right?
20:27 Yeah.
20:28 Yeah.
20:28 So, this one is a little bit of a serious one or at least addressing a serious problem, right?
20:34 It's not like putting mustaches on cats, but, like, it's actually trying to solve a problem.
20:38 Although, that would be a hard thing to do audibly on Alexa.
20:41 Nonetheless, so, this one.
20:45 This one is called Depression AI.
20:47 And it's an Alexa skill.
20:49 I apologize.
20:50 Everybody's little device is probably going off.
20:52 It's a Amazon device skill for people who are suffering with depression.
20:58 And it's open source.
21:00 It's based on Flask Ask, which I covered pretty deeply on episode 146 of Talk Python.
21:07 So, that's basically a way to use Flask to write these Amazon voice assistant skills, which is pretty cool.
21:14 So, the idea is that if you are suffering from depression, one of the things that's really hard for people, apparently, who are suffering from depression is to sort of go about your normal daily routine, right?
21:28 Get up.
21:28 Make your bed.
21:29 Take a shower.
21:30 It's, like, easy to just sort of, like, stay sprawled out on the couch or the bed or whatever.
21:34 And so, it sort of helps to encourage you to keep doing those things.
21:39 And it's supposed to be able to detect your moods and kind of give you some feedback.
21:44 What do you think?
21:44 I think that's super impressive.
21:46 I mean, I have relatives who have dealt with these sorts of issues.
21:50 And I don't know that they're necessarily ones who would take to technology.
21:54 But anytime you can get some help or get, you know, some feedback or someone other, you know, you're not listening to yourself, it can be a good thing.
22:03 I think this is awesome to have.
22:05 I think there's a lot of people that would aren't somebody that wants to go talk to somebody else, but having making the decision to put this in place when they're feeling good and then have it help them through the hard times.
22:17 This would be great.
22:18 Yeah, it's pretty cool.
22:19 It won the Valley Hackathon, which I think is, I think that's in Modesto, sort of outside San Francisco.
22:25 But this was apparently built like, what is that, a weekend or something, which is also a pretty, pretty big testament.
22:32 So you can do things like it'll evaluate your mood.
22:35 It actually has suicidal intervention.
22:37 It has location-based recommendations and mostly helps you with small activities.
22:41 So you can say things like, Alexa, check on me, or I feel down, or help me feel better.
22:47 I haven't gotten out of bed today.
22:48 It'll ask you things like, have you gotten out of bed yet?
22:51 Things like that.
22:52 So it's pretty cool.
22:54 Yeah, that's also open source.
22:55 Yeah, it's open source and on GitHub and based on Python.
22:58 So if this is inspiring, even if it's a totally different subject area, take it and use it as an example.
23:03 Nice.
23:04 Well, that's it for our official news.
23:06 Brian, you got anything you want to share with the world while we're here?
23:09 I've got some good news and some bad news.
23:12 So the good news is I went to an estate sale the other day and I bought a book called How to Be Interesting in 10 Simple Steps.
23:21 So that's the good news.
23:22 The bad news is I'm a really slow reader, so it might take a while to take effect.
23:26 Step two.
23:28 No, I've just skimmed it so far, so I haven't even started yet.
23:31 Well, what's a book?
23:32 Yeah, very quick.
23:33 What's your interest?
23:33 It was printed a long time ago before we had e-books.
23:37 Is it one of those things on paper?
23:39 It's like a tablet, but it doesn't run out of batteries?
23:42 Is that what you're telling me?
23:42 I've got another book author harassing me about physical books.
23:47 How about you, Matt?
23:47 You got any books lined up?
23:49 I'm working on revamping my Pandas one.
23:52 So big demand for Pandas and I want to update mine to the latest version.
23:56 So it's .17 and that's a couple years out.
24:00 Sure, very cool.
24:01 Oh yeah, and we also have some news about maybe a course coming out from you.
24:05 We'll leave that as a teaser, but I think a video course maybe in the near future.
24:10 Yeah, yeah.
24:11 Maybe.
24:12 I don't know.
24:13 We'll have to see.
24:13 We'll have to see if we can get our act together.
24:15 Awesome.
24:16 All right.
24:16 Well, Matt, thank you for joining us and dropping in on this podcast.
24:20 And Brian, thank you as always.
24:21 Yeah, thanks.
24:22 My pleasure.
24:22 Thank you.
24:23 Yep.
24:23 Bye, guys.
24:24 Bye.
24:26 Thank you for listening to Python Bytes.
24:28 Follow the show on Twitter via at Python Bytes.
24:30 That's Python Bytes as in B-Y-T-E-S.
24:33 And get the full show notes at pythonbytes.fm.
24:37 If you have a news item you want featured, just visit pythonbytes.fm and send it our way.
24:41 We're always on the lookout for sharing something cool.
24:44 On behalf of myself and Brian Okken, this is Michael Kennedy.
24:47 Thank you for listening and sharing this podcast with your friends and colleagues.