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


Transcript #49: Your technical skills are obsolete: now what?

Return to episode page view on github
Recorded on Tuesday, Oct 24, 2017.

00:00 Hello and welcome to Python Bytes, where we deliver Python news and headlines directly to your earbuds.

00:05 This is episode 49, recorded October 24th, 2017.

00:10 I'm Michael Kennedy.

00:11 And I'm Brian Okken.

00:12 And we have yet another six or more amazing news items, actually tons of really cool stuff to share with you.

00:18 But before we get to them, I want to say thanks to DigitalOcean for creating spaces and sponsoring this podcast to tell you about spaces.

00:26 Spaces are like S3, but way, way better.

00:29 And check them out at do.co slash Python.

00:32 Tell you more about that later.

00:33 Right now, I want to go watching some videos.

00:35 Yeah, I know there's a lot of conferences that go on around the world.

00:39 And actually, anybody that's doing a Python conference, I have no problem with trying to highlight those.

00:45 So let us know when they're going on and also when their videos are up.

00:48 And that's what I want to talk about right now is there's a couple conferences who have videos available now.

00:54 DjangoCon and PyGotham both happened recently.

00:57 And both of their videos are available.

00:59 So we've got links to both.

01:01 PyGotham is on.

01:02 Yeah, I don't know if it's on YouTube or not, but it is up on pyvideo.org.

01:08 And the DjangoCon 2017 is up on YouTube.

01:11 And I've got links to both those playlists.

01:14 I was excited to look at a lot of these.

01:17 And one of the videos I started off with was a video from DjangoCon called Django vs. Flask.

01:24 And it was by DB David Baumgold.

01:27 That sounds fun.

01:28 It actually was interesting because it's somebody that respects both Django and Flask.

01:33 And it was probably one of the best Flask videos I've watched talking about how to deal,

01:40 kind of how to do some of the things you can do in Django right out of the box,

01:44 but how to do it in Flask and comparing those.

01:47 It was cool.

01:47 That sounds like a really cool video.

01:49 It's one thing to go study Django.

01:51 It's one thing to learn Flask.

01:53 But to see the features side by side sounds like a really nice way to...

01:56 If you're new and you're trying to decide, should I go with Flask or should I go with Django?

01:59 This is like half an hour, 45 minutes.

02:02 You'll have probably a really good idea rather than you've got to like spend hours learning each and then decide, right?

02:08 It sounds like he leans.

02:09 He likes the flexibility of Flask.

02:11 However, it's obvious that he has respect for both.

02:15 And he's talking at a Django conference, of course.

02:18 There's some things I didn't even know about, which was cool.

02:21 I didn't know about Flask blueprints.

02:23 And I also definitely never heard of Flask Marshmallow for APIs before.

02:27 Marshmallow.

02:28 Yeah, that's great.

02:29 And it covers things like SQLAlchemy, Mongo Engine, PeeWee, all the great ODM, ORM data access layers.

02:36 It's cool.

02:37 Yeah.

02:37 But there's so many other great videos up from those two conferences.

02:41 And I really appreciate that.

02:42 That part of the Python culture that we try to make the conference videos available for people.

02:48 Yeah, that's great.

02:48 I love that these conferences are so quick about getting the videos up.

02:52 The videos are really high quality usually.

02:54 The sound is good.

02:56 Everything's in focus.

02:57 A lot of times it's picture in picture.

02:58 I mean, well done.

02:59 So that's nice.

03:00 What do you got for us, Michael?

03:01 Well, I want to pay a little attention to Facebook.

03:04 Because Facebook does a lot with Python, actually.

03:07 People will tell you Facebook is written in PHP.

03:10 And that it uses React, the JavaScript framework, which they invented on the front end.

03:14 So it's like PHP plus React.

03:16 And that's interesting.

03:17 But it turns out that I don't work there.

03:19 I don't really know a lot of people there.

03:20 But from what I've been able to read, there's a decent amount of Python backend services sort of supporting that PHP front end.

03:29 Okay.

03:29 Wow.

03:30 Yeah.

03:30 And so that's pretty cool.

03:31 And there was a tweet from one of the guys there, L Lange.

03:35 I think he works there.

03:36 I'm pretty sure he works there from the reading of the tweet.

03:39 But he was talking about Facebook and said, hey, Python 363 was released on Tuesday.

03:44 And I think last Tuesday you covered that, which is pretty awesome.

03:48 This was, maybe this was two weeks ago.

03:51 When it was released, though, they said this tweet was three days after that.

03:54 And it said, all the machines at Facebook are already running Python 363.

03:58 That's cool.

03:58 Three days.

03:59 And they said that 36.3% of their Python apps are based on 36 already.

04:07 How about that?

04:08 That's great.

04:09 Man, I love 36 now.

04:10 I do too.

04:11 The f-strings are just so delightful.

04:13 Yeah.

04:14 And so this is super interesting.

04:16 And what's more interesting is I would say 20.

04:20 Oh, gosh, I'm forgetting the numbers.

04:21 I'll have to just send you guys to the video and let you pull the numbers out.

04:25 But a couple years previously, Facebook was not friendly to Python 3.

04:29 Basically, they had just gotten access to Python 2.7 from 2.6.

04:34 Okay, that was the big upgrade.

04:36 And all the recommendations were to use Python 2.

04:40 The onboarding processes said, hey, when you get here, you're expected to write in Python 2,

04:46 et cetera, et cetera.

04:47 And this guy named Jason Fried, not of 37 Signals fame, but a different Jason Fried,

04:52 took over the process of trying to shift the organizational culture to valuing Python 3 as the default

05:01 and making the people that do Python 2 look kind of outdated and funky.

05:05 So there's this really great presentation called Rules for Radicals, Changing the Culture of Python at Facebook.

05:10 And it's step by step.

05:13 It's a step by step playbook, basically, of how he transformed the culture to where we're in this place

05:21 where you say Python 3.6.3 was released on Tuesday.

05:24 Facebook machines are now running it.

05:26 And that tweet comes out on Friday, right?

05:28 So this is not like, well, Facebook's a startup.

05:32 It can always do like.

05:33 No, it was this huge organization transformed through clear, simple, repeatable steps.

05:39 So I think this is just a really cool evidence of Jason Fried's work.

05:43 And well done, Jason, and everyone at Facebook.

05:45 Yeah, and I can't wait to watch this video.

05:47 Thanks for linking to it.

05:48 Yeah, yeah, it's super cool.

05:49 It was at PyOhio a couple years ago.

05:52 And in more modern Python news, Ubuntu 17.10, which just came out, and I upgraded one of my servers recently to it.

06:00 It says Python 2 is no longer installed by default, and Python 3.6 has been upgraded to 3.6.

06:07 How about that?

06:08 That's great.

06:08 Another step forward.

06:10 All right, so modern Python is on the march.

06:12 And 3.3 is end of life, probably by the time this comes out.

06:16 It's already end of life.

06:17 So if you have something on 3.3, it is time to move up.

06:21 And if you're going to move up, don't go to 3.4, go to 3.6.

06:23 Speaking of new technologies, there was a pretty good article, and it's not Python specific,

06:28 but called Your Technical Skills Are Obsolete, Now What?

06:32 And this is, it's actually a pretty fun article about, you know, since you and I are both big

06:38 proponents to people keeping their skills up to date and learning new things, I thought

06:42 it fit in nice.

06:44 And this article is focused on how to do that while at work, to not try to eat into

06:50 your home life to beef up your skills.

06:53 I think there's a lot of people who feel kind of in a tough situation because they see all

06:57 these new technologies coming out, and they hear presentations or people say, oh, the stuff

07:03 that you do is so old and crappy.

07:04 You should be doing whatever whiz-bang new thing it is.

07:07 These recommendations or this excitement, probably rightly so, but it comes from people who

07:12 are young.

07:13 Maybe they don't have kids or they're single and they have a lot of free time.

07:17 And to spend an extra two hours after work on some project is like no big deal if you're

07:22 young and you've got lots of free time and energy.

07:24 But if you're getting dinner for the kids and you've been up early driving to school and you've

07:29 got to work with homework, it's just like, it's a whole nother level, right?

07:32 I think it's a great idea to try to fit that into your work if you can.

07:36 One of the things is I really like that he starts off by talking about the reasons, sometimes

07:42 good reasons why companies stay with an old technology.

07:45 However, I mean, if Facebook can switch in a few days, what's your company's excuse?

07:50 That's right.

07:51 Seriously, though, sometimes there's good reasons to not jump on the bandwagon right away.

07:56 So he goes through some steps of identifying obsolete and problematic technologies and

08:02 trying to do some research on potential replacements and then trying to get buy-in from your management

08:07 and hopefully to try to get some time for yourself or maybe you and some other people to do a pilot

08:14 project exploring this process.

08:16 Yeah.

08:16 The main message of this was, look, if you want to find a way to learn new skills, you need

08:22 to fit it into work often, right?

08:25 Unless you just want to really put in a lot of energy to learn something outside of work.

08:28 But if you're going to try to fit into work, go and identify a problematic area of your technology

08:33 stack and see, like create a plan on how to solve that problem with the new technology by

08:41 you.

08:41 Thereby, you learn the new technology by solving the problem.

08:44 So you're actually adding value, not just saying, please send me to training.

08:47 You didn't sit me in six weeks or six months, whatever, right?

08:50 So then he does talk about how to pose those questions and talk to your manager about making

08:56 the change.

08:56 But he kind of ends with, if your boss says no, then you at least have some extra skills

09:02 that you can apply to your next job.

09:03 And I'd like to shim in there and say, I think you should use it to start a conversation with

09:10 your boss or your management chain about that you care about the company, you care about increasing

09:15 the skills of both yourself and the others on your team.

09:18 And how can you go about doing that?

09:21 And why?

09:21 Why the no?

09:22 Like, is it bad timing or you just have a bad proposal or too much time spent?

09:27 Anyway, I think that you should try to not throw your company under the bus right away and

09:33 try to work a little harder.

09:34 So I think actually your, the video you linked to with the rules for radicals probably fits

09:41 right in here too, of trying to change your company.

09:43 Yeah, absolutely.

09:44 You don't just like Jason didn't just go, well, I said Python too.

09:47 So I'm going to go find a startup.

09:48 Forget this, right?

09:49 He, he actually changed Facebook, which is even more impressive.

09:52 And then a book that a little tiny, it's a little tiny read, a book I read a couple of

09:56 years ago is called Team Geek that has some great advice on this.

10:00 And it says that things like changing your process, you probably ought to limit it to under

10:06 50% of your time.

10:08 I would say stronger.

10:09 I would say 10 to 20% of your time at most trying to fix things.

10:13 And then the other thing is there's a nice section on, sometimes it's easier to ask for forgiveness

10:20 than permission.

10:21 You can try to get your manager buy-in, but also if you're not spending much time on it,

10:25 you might be able to just change some things and make it better.

10:28 Like one of those disclaimers, this, my advice cannot be taken as legal advice and you should

10:33 seek your own legal counsel, but.

10:35 Yeah, your conditions may vary, but I think this is good.

10:39 I think it's really good advice.

10:40 And this article is really practical, especially for people who are not trying to spend an extra

10:44 hour a day outside of work learning something.

10:46 So that's really cool.

10:48 I feel like there's a lot of slack in big organizations already.

10:52 You get put into a lot of meetings.

10:55 You have a lot of, I don't know, there's time between the actual work that seems to get done.

11:01 And if you can just wall off like a little bit of that for learning and working on a project,

11:06 it could be like a skunk work thing.

11:08 I'm trying to prototype something different or I'm just learning something.

11:11 But if you could like, say, find an extra half hour a day to be studying something in the

11:16 context of your work that you're trying to learn, that actually could make a huge difference

11:19 over a couple months.

11:20 So that's usually pretty good to do.

11:22 I completely value in my employees somebody that really wants to increase their skill set

11:29 and also cares about saving the company money and making things better.

11:34 So at the very least, your management chain should know that you care about that too.

11:38 They should care about that.

11:39 People who care about this stuff and who are actively working on it, those are the type of

11:43 people you want.

11:44 The ones that don't complain, that are just going to work on that old 20-year-old technology,

11:49 that's fine that they're great employees and they're doing that.

11:51 But that's not going to push you guys forward.

11:54 So definitely, I think people should see this as a positive.

11:57 Awesome.

11:57 Speaking of making and making things better, DigitalOcean has made online cloud storage

12:03 for apps much, much better with their new thing called Spaces.

12:06 So check out Spaces at do.co slash Python.

12:10 And the idea is it's a similar service to Amazon S3, right?

12:15 You have just a cloud storage.

12:17 You can have either private or public things stored up there.

12:22 Huge, huge amounts of data.

12:24 If your app has, say, processed a bunch of pictures and you've got to store the picture

12:28 somewhere, instead of jamming them in the database, put the gigs of pictures up in Spaces.

12:32 And it's really easy to adopt because it uses the same APIs as S3.

12:38 So tools like the Transmit app I use on my Mac, I just pointed at the URL for Spaces and I tell

12:45 it's an S3 thing and it just works.

12:47 So that's super cool and easy to do.

12:49 The pricing is so much better than S3.

12:53 $5 a month flat for 250 gigs of storage, a terabyte of outbound bandwidth, which would

12:58 be like $90 alone on S3.

13:01 And then it's just one cent per gigabyte instead of nine.

13:04 So definitely, definitely check it out.

13:07 I'm using it for this podcast and many other things.

13:09 The audio you're listening to came over it.

13:12 So how about that?

13:12 It's super easy to use and it's a great deal and very predictable.

13:16 So do.co slash Python and check out DigitalOcean Spaces.

13:20 Let's talk about visualizing things as well here.

13:24 So last week you brought up that deep dive inside of garbage collection.

13:28 That was a super good article.

13:30 And I really appreciated getting a look at how the reference counting GC worked, about how the

13:35 actual mark and sweep garbage collector that would solve the cycle problem worked, how Python

13:41 uses that combination of them.

13:42 And a lot of the really nice details about at this number, it behaves differently if it's

13:47 bigger or smaller, right?

13:48 These little cutoffs are always fun to know.

13:49 There are many different garbage collection algorithms of which reference counting and mark

13:55 and sweep are just one.

13:56 So this guy named Ken Fox, it's not a brand new article or anything, but it's really a

14:01 cool follow-up.

14:01 Wrote this thing called Visualizing Garbage Collection Algorithms.

14:05 And yeah, I think this is, if you like the last article, you should definitely check out this one.

14:09 The little videos on visualizing this are, they're kind of mesmerizing.

14:15 I kind of want to like leave one up on my screen or something.

14:18 They're great.

14:19 Yeah, exactly.

14:20 If you could have a screensaver of visualized GCs, it would be beautiful.

14:25 We need that company that made the toasters, the flying toasters.

14:28 We need them to make that, right?

14:30 Even though I covered it last week, I'm trying to remember.

14:32 The Python is both a reference counting collector and a mark sweep collector, right?

14:37 Right.

14:38 So by default, Python tries to use reference counting.

14:41 So every time you have a pointer to an object, it increments the counter.

14:45 And then once that counter goes back down to zero, then it just deletes it.

14:49 The problem with all reference counting collectors are, if you have any form of cycle, that's straight up a memory leak right there, right?

14:57 Parent, child, child, parent, boom, never goes to zero, never deleted.

15:00 That can be a huge problem.

15:02 And so there's ways to solve that.

15:05 Usually that's some other kind of managed garbage collector, right?

15:09 And that's why they bring in the mark and sweep one, because it goes and finds these cycles and gets rid of them.

15:14 One of the questions I have that I don't expect you to have the answer, I'm curious about it, is if fragmentation becomes a problem within Python or not.

15:22 I think it does.

15:23 I think it does.

15:23 You can actually see it in the picture.

15:25 So let's go through the five visualized here.

15:28 So there's actually five different types of GC.

15:29 There's no GC, which just means we're just going to allocate and not clean up stuff.

15:34 Hopefully we won't spend too much memory, and that'll be fine.

15:38 Like, that's actually a super efficient way as long as you have enough memory.

15:43 And it might sound outrageous, but Apache, Apache web server, actually creates small pools of memory per request and then just throws them away and doesn't try to manage that memory.

15:52 Dirty.

15:53 So, you know, I guess in like small doses that could work.

15:56 There's the reference counting one, and that's Python's first pass, as we talked about.

15:59 There's a mark and sweep collector, which goes and says, I'm going to start at all the known pointers that I have, follow them, the things they point to, da, da, da, right?

16:09 Follow all that sort of transitive closure of pointers and indicate or mark everything that is not garbage.

16:17 So it's like a not garbage finder.

16:18 And whatever it doesn't find, well, that's garbage.

16:20 And then there's some stuff more like Java and .NET and those types of things that are mark and compact collectors.

16:28 All right.

16:29 So Python, you asked about the fragmentation.

16:31 It doesn't, as far as I know, it doesn't move the memory around and change where the pointers point.

16:36 After it does a collection, it just cleans up the cycles.

16:39 Right.

16:40 And so if you had like a 10-byte object in between two things that got cleaned up, that 10 bytes is just a hole.

16:46 Right.

16:47 Maybe you can fill it.

16:48 Maybe you can't.

16:48 But the compacting ones, those will like squish the memory back together.

16:53 And what's interesting about the compacting ones is allocation in a compacting collector is insanely fast.

16:59 Probably faster than C++ or C.

17:02 Because you don't have to traverse that list of open slots where your new memory might fit.

17:07 You just always allocate at the end because you've compacted it down.

17:11 Right.

17:11 So allocate means increment a pointer by, you know, you want 10 bytes, you increment the pointer by 10.

17:16 Done.

17:16 Right.

17:18 So it's pretty interesting.

17:19 There's a couple of kinds.

17:20 And so this goes through and visualizes all of these.

17:23 And you can actually see the effect and you can see the fragmentation that you were talking about in the reference counting one.

17:28 But it's pretty cool, this set of visualizations.

17:31 Definitely.

17:32 You know, I feel like I should be using Pathlib more than I do.

17:36 And I just do os.path.join and that sort of stuff.

17:40 They're the older style of working with paths in Python.

17:42 And that's worked with me.

17:44 But this article by Doug Hellman that you pull out here, this is pretty cool.

17:48 And it makes a solid case for Pathlib.

17:50 Yeah, actually.

17:51 And so I went back and I'm like, when did Pathlib come in?

17:54 And suppose it came in introduced in Python 3.4.

17:58 So it's a Python 3 new thing.

18:00 It's an object-oriented system to work with paths.

18:03 So paths as objects.

18:05 And like we're pointing to Doug Hellman's Python module of the week, the Python 3 version.

18:13 And it's pretty good.

18:15 It's a very quick read to skim over all the sort of stuff you can do.

18:19 Yeah, I learned things just the other day thinking, oh, my gosh, I've been using OS too much.

18:24 I should use this more.

18:25 Yeah, for sure.

18:26 And I was really blown away at the way you use the division to hack the visual, right?

18:33 Like the way you use the divider, like forward slash.

18:36 So you can have like one path forward slash the other path.

18:39 And it just joins them as if it was this thing slash that thing in the actual string, right?

18:43 And you can use that division operator with either path objects or just some quote strings and characters and quotes to add things to your path.

18:53 And I didn't know that it had glob in there.

18:55 So that's pretty cool.

18:56 And iter dirs.

18:58 Iter dir for like iterating over files in a directory.

19:01 That's pretty nice.

19:02 Right.

19:03 One of the things that's annoying about OS.path is if you want to actually create directories or delete them or stuff, there's like all these unrelated ways.

19:11 Like you go out to other areas, you know, like OS.maker rather than OS.path.maker.

19:17 It's just funky inconsistencies.

19:19 And this like brings it all together.

19:20 You can like create and delete directories and things like that.

19:23 And then there's some top level stuff for concrete paths that are shortcuts like path.home and path.cwd that just work whether you're on Windows or a Linux-based POSIX system.

19:36 Yep.

19:36 That's really nice.

19:37 Cool.

19:38 Yeah.

19:38 So definitely speaking of learning new things, here's something people can learn.

19:42 This is great.

19:42 So we talked about visualization before, but, you know, can computers see?

19:47 Yeah, sure.

19:48 I think they can.

19:49 I mean, cars, we're surprisingly close to a world where cars can drive on their own.

19:54 Are you ready?

19:55 Yeah, I'm totally ready.

19:56 Yeah.

19:56 I mean, we've got a whole bunch of deep learning stuff happening.

20:00 NVIDIA made a car.

20:02 I think we talked about this before where like they just had it observe humans and they made it go drive.

20:07 And like they don't know how it knows how to drive, but it can.

20:09 Things like this, right?

20:10 They didn't teach it to drive.

20:11 It just like learned.

20:12 And so I want to highlight this thing called Luminoth, an open source computer vision toolkit.

20:19 So this is a new computer vision toolkit for Python, and it uses deep learning to understand computer vision.

20:26 So basically its main job right now is to work on object detection and classification, but they're trying to do a lot more with it.

20:35 Like that was the first problem they solved.

20:37 So it's built Python, it uses TensorFlow and Sonnet, which is Google's deep learning framework and deep minds graph library.

20:44 So these are really cool.

20:47 This is the same thing that Google is using very likely for things like its AI that just beat Go.

20:53 Or it had beat Go before, but they just announced that there's a new AI that beat Go without anyone teaching it how to play Go.

21:01 So that's news this week as well, by the way, although I don't have a link to the article.

21:07 So you can super easily train this thing.

21:09 It's like a couple of lines of code, and then you can start asking it to find stuff in objects.

21:15 And it'll say, that's a bike.

21:16 That's a hand.

21:17 That's a person.

21:18 The face is over here.

21:19 No, that's three people.

21:20 Things like that.

21:21 Really, really cool.

21:22 And it uses this modern state-of-the-art algorithm called Region-Based Convolutional Neural Networks.

21:29 R-CNNs.

21:31 It even comes with GPGPU support.

21:35 And it's cool.

21:36 They even are going to send pre-trained checkpoints for objects that is already pre-classified with some really large data sets from other challenges.

21:46 Oh, wow.

21:46 That's great.

21:46 Isn't that cool?

21:47 So if you want to go and create a project that does some sort of image classification or identifies objects in images, check this out.

21:54 Because if it comes with pre-trained algorithms already, and you have a similar type of data as what they already trained it on, you might be able to just pick this up and use it.

22:03 Yeah.

22:04 Well, one of the examples it shows is detecting dinosaurs in a picture.

22:08 Yeah.

22:08 That's awesome.

22:09 So you could build like a home security?

22:11 Yeah.

22:11 It'd be useful so that you could find out if a dinosaur is at the door.

22:14 Don't open it.

22:16 No, it's a dinosaur.

22:17 It'd be great.

22:18 If you could come up with a doorbell that rings differently based on what it detects.

22:26 Oh, nice.

22:26 If it detects a kid, like one of your kid's friends is at the door, it could make one kind of noise.

22:32 If it's a UPS guy, it could make a package noise.

22:35 I mean, wouldn't that really be a cool product?

22:37 Yeah, like a really big happy sound if it's a pizza delivery guy.

22:40 Yes.

22:41 Pizza.

22:41 You've got mail.

22:44 Let's do that.

22:44 Yeah.

22:44 That sounds like a very good business.

22:46 Let's do that.

22:46 All right.

22:47 So anyway, if you guys are into image recognition, check this out.

22:51 It's a cool project.

22:52 Luminoth.

22:52 It's fairly new.

22:54 You got a bonus for us, right?

22:55 Yeah.

22:55 I was going to put this as one of my picks, but it felt kind of...

23:01 Anyway, there's a bonus article called The Cleaning Hand of pytest.

23:04 And it's somebody else's experience of what it was like to work in unit test and nose after using pytest.

23:11 And I feel a little...

23:13 Actually, I don't feel bad at all.

23:15 But at the end, he links to my book, which is good.

23:17 So check that out.

23:19 Oh, that's nice.

23:19 That's a nice validation.

23:20 That's cool.

23:21 Yeah, The Cleaning Hand of pytest.

23:22 That sounds really fun.

23:23 How about you?

23:24 What's up with you?

23:24 Well, not a whole lot going on.

23:26 I wanted to highlight two things.

23:27 You mentioned the various PyCons going on.

23:29 And PyTennessee 2018 is coming up.

23:33 So if you're anywhere near Nashville and you want to go to a PyCon, you don't want to wait until May to go to the big, big PyCon in Cincinnati.

23:41 I think it's somewhere in Ohio this year.

23:43 You can go in February 10th and 11th and go to one in Nashville, PyTN.

23:49 So check that out.

23:50 That's really awesome.

23:51 That'd be fun.

23:52 Yeah.

23:52 I was thinking of trying to go.

23:54 But it turns out that my wife's already out of town that week.

23:58 And with children, we can't both be out of town the same week.

24:01 So that sort of squashed that.

24:03 The other thing really quick is I wanted to point out a movie.

24:06 It's not super new.

24:07 It's like a couple years old.

24:08 But I think people in this audience will really appreciate it.

24:10 Are you into gaming, Brian?

24:12 No.

24:13 Yeah.

24:13 I'm not either.

24:14 I'm kind of oblivious to this world and what has happened to it in the last five years.

24:19 But there's this movie called All Work and All Play.

24:21 It's available on Netflix.

24:22 I linked to the trailer.

24:24 And it is a really interesting look inside what has been going on in the world of professional gaming.

24:31 Wow.

24:31 So if you're into that, there's basically, they had the world championship of gaming they had in Poland.

24:38 And there's some big upsets and surprises.

24:40 And I think they said 100,000 people attended in person.

24:43 I mean, it's like insane.

24:44 So if you haven't been paying attention to this, this movie is pretty eye-opening.

24:50 So this is people playing video games?

24:52 This is a competition of League of Legends players.

24:55 I think there were six teams.

24:56 Okay.

24:57 Six or eight.

24:57 No, eight teams, I think.

24:59 And then these are people watching the games being played live in person.

25:03 So you're not a gamer either.

25:04 We found two nerds talking to each other, and both of them are not gamers.

25:08 No, not really.

25:10 I mean, my...

25:11 What are the odds?

25:11 I know.

25:12 It's pretty low, I guess.

25:14 My pastime is to work on software projects.

25:17 That's my game.

25:18 It's like solving software problems, not, you know, made-up game problems.

25:21 Every now and then I'll play an iPad game or something, but nothing major.

25:23 Yeah.

25:24 Okay.

25:24 Well, cool.

25:26 All right.

25:26 Well, thanks a lot.

25:27 You bet.

25:27 And I'll catch you next week.

25:29 Thanks, everyone, for listening.

25:30 Bye.

25:30 Thank you for listening to Python Bytes.

25:34 Follow the show on Twitter via at Python Bytes.

25:36 That's Python Bytes as in B-Y-T-E-S.

25:39 And get the full show notes at pythonbytes.fm.

25:43 If you have a news item you want featured, just visit pythonbytes.fm and send it our way.

25:47 We're always on the lookout for sharing something cool.

25:50 On behalf of myself and Brian Okken, this is Michael Kennedy.

25:53 Thank you for listening and sharing this podcast with your friends and colleagues.

Back to show page