#15: Digging into Python packaging
This is Python Bytes, Python headlines and news delivered directly to your earbuds: episode 15, recorded on February 27, 2017.
#1 Brian: Packaging A Simple Guide for Python Packaging *by *Jie Feng, @flyfengjie
- very simple bare bones example and tutorial
- When you create a ‘.py’ file, that is a module.
- One or more modules in a folder with add a __init__.py file is a package (named via the folder)
How To Package Your Python Code **by Scott Torborg, @storborg
- The example from the previous article comes from this.
- The best mid level explanation I’ve run across so far to describe packaging and distribution.
- Read the whole thing in a very short time.
#2 Michael: elasticpypi by Kyle Hornberg
- A mostly functional simple pypi service running on AWS.
- Runs over Elastic Search and AWS Lambda
- Compare to
- pypiserver: https://pypiserver.readthedocs.io/en/latest/
- devpi: http://doc.devpi.net/latest/
- pypiserver: https://pypi.python.org/pypi/pypiserver
 
#3 Brian: How to get Python news (our process)**
- PythonBytes.fm, of course
- Twitter: 
- Brian: https://twitter.com/brianokken
- Michael: https://twitter.com/mkennedy
- Talk Python: https://twitter.com/TalkPython
- Python Bytes: https://twitter.com/PythonBytes
 
- http://planetpython.org/, check out the titles only link, as well as reading this feed with Feedly or some other feed reader
- Newsletters:
- Awesome Python: https://python.libhunt.com/newsletter
- Python Weekly: http://www.PythonWeekly.com
- Pycoders Weekly: http://www.pycoders.com
- Import Python: http://importpython.com/newsletter/
 
- Reddit: https://www.reddit.com/r/Python/
- Python Trending on GitHub: https://github.com/trending?l=python
#4 Michael: Curio - The coroutine concurrency library, by David Beazley, @dabeaz
- Curio is a library for performing concurrent I/O and common system programming tasks such as launching subprocesses and farming work out to thread and process pools.
- It uses Python coroutines and the explicit async/await syntax introduced in Python 3.5.
- Based on cooperative multitasking and existing programming abstractions such as threads, sockets, files, subprocesses, locks, and queues.
- Only works on POSIX systems
- The Big Question: Why?
- Python 3.4 and 3.5 have added major new paradigms for async programming.Curio takes full advantage of these features and is not encumbered by issues of backwards compatibility with legacy Python code written 15 years ago.
- Curio is a ground-up implementation that takes a different approach to the problem while relying upon known programming techniques involving sockets and files.
- The implementation of Curio aims to be simple. The API for using Curio aims to be intuitive.
 
 
- Python 3.4 and 3.5 have added major new paradigms for async programming.Curio takes full advantage of these features and is not encumbered by issues of backwards compatibility with legacy Python code written 15 years ago.
#5 Brian: Pandas switching to use pytest as testing framework
- Interesting look at the challenges and discussion of moving a large, highly visible project
#6 Michael: Talk Python #100: Python past, present, and future with Guido van Rossum
- Excellent look back and forward with Guido
- Conversation on reddit
- Conversation on hackernews
- We touch on
- How he got started
- Early influences on Python
- Why Python succeeded
- How are we doing with: Diversity and moving to Python 3?
- His favorite features of Python 3
- Converting legacy code via mypy: http://mypy-lang.org/
 
In other news (as in our news)
- Test & Code 27 is out, a great talk with Mahmoud Hashemi on different levels of testing, the role of testing in SW development, TDD, and what he’s been up to lately. Test & Code migrating to testandcode.com, to separate writing and podcast into two sites. When it gets cleaned up a little, I’ll forward podcast related links from pythontesting to testandcode. 
- The pytest book got sent out to a few reviewers, and we have a title and some cover art options. It’s getting exciting. The rest of the reviewers will get the book when all chapters have gone through at least one editor iteration. 
Episode Transcript
Collapse transcript
00:00 This is Python Bytes, Python headlines and news delivered directly to your earbuds.
00:04 That's episode 15, recorded Monday, February 27th, 2017.
00:10 This is Michael Kennedy. I'm here with my co-host, Brian Okken.
00:13 Hey, Brian. Happy Monday. Happy Python News Day.
00:17 Yes.
00:18 And today we're going to have a couple of really interesting items, and we're going to start off with a theme.
00:24 And the theme is people should probably understand Python packaging and distribution better.
00:29 Right.
00:30 Yes, definitely.
00:31 I come up with this.
00:32 Actually, it jumps up on you as a surprise, I think, as soon as you try to share some Python code with somebody,
00:39 even if you're just sharing it within your own work group of dealing with packages.
00:44 So there's a blog post out on, I think it was on Medium, by Ji Fung, A Simple Guide to Python Packaging.
00:52 And it's actually a really quick read, and it's a really nice introduction to talk about where to put the init file,
00:59 and, you know, just basically what is a package and how to deal with it, even to the extent of pushing something up to PyPI.
01:07 Yeah, it's a good article.
01:08 Yeah, I thought it was really nice, and it's like five minutes or less to read, right?
01:13 So definitely jump in.
01:14 Yeah.
01:15 One of the things that I was reminded of while I was reading it, I knew it, but just, you know, wasn't on the top of my mind,
01:20 is the difference between modules and packages.
01:24 And, you know, many people know the differences, but if you haven't worked with Python packaging, maybe you don't.
01:29 And so people, I feel like people often use module and package interchangeably.
01:34 Like, these are synonyms, and we just swap them, right?
01:37 You import module, import package, whatever.
01:39 There's a difference, right?
01:41 Like, a module is a single Python file, where technically what defines a package is it's a directory with a dunder init.py and one or more Python files in it, right?
01:53 Or I guess it could be empty.
01:54 It just does nothing, right?
01:55 But it's more, Python treats those differently if it finds that dunder init.py.
02:00 Yeah, it's very important with sharing code.
02:02 But one of the nice things, at the bottom of the article, there was a link to another article, actually an entire set of instructions called How to Package Your Python Code by Scott Torborg.
02:14 He's a Portland person.
02:16 Oh, right on.
02:17 Yeah, go Portland.
02:18 It's a longer introduction, but it's still like, I read it in like a half an hour, the entire site.
02:24 It's a fairly detailed look at packaging.
02:27 I think actually that this documentation should be included and incorporated into the PyPI documentation because it's really good.
02:35 You think it's that good?
02:36 That's awesome.
02:36 Yeah.
02:37 All right, way to go, Scott.
02:37 So the next item that I wanted to talk about is also related to this.
02:42 So I feel like this is the next layer up.
02:44 All right, so once you get into packaging and start packaging your code, one of the reasons you might do that is if you're building a package for the world, that's cool, right?
02:52 Submit that to PyPI and everybody can play with it.
02:55 But another reason is you just want to reuse that code.
02:58 And maybe this code is proprietary code and you don't want to reuse it with the world.
03:01 You want to reuse it maybe only within your company, right?
03:04 So one of the cool things you can do is set up your own PyPI server.
03:09 And then that's private behind your firewall with authentication or whatever.
03:13 And you can put your code there.
03:15 And then across your different apps, across your different teams, across continuous integration, as long as it has access to this, you can basically put additional private stuff, including your proprietary libraries in there, which I think that's really cool.
03:28 So the thing I brought up was an interesting take on this idea called Elastic PyPI by Kyle Hornberg.
03:36 So the idea is we're going to take this and we're going to use Elasticsearch and AWS Lambda for a serverless deployment of your own private PyPI.
03:45 Okay.
03:46 So the AWS Lambda stuff is like, here, I can give you a Python function and I'll give it to AWS and it lives at the end of a URL.
03:55 And it's just basically you make a request, it runs it, right?
03:58 You don't have to set up a server or it's even like a little bit less than platform as a service.
04:03 It's like really, really lightweight.
04:05 So it's a combination of this and Elasticsearch, which I thought was kind of cool.
04:08 Yeah, that's pretty neat.
04:09 I'm still looking for the right solution for internal to a company inside of a firewall.
04:15 I haven't quite stumbled upon the right thing yet.
04:19 Yeah, I know there's, so I actually listed three other ones that I know about that are in this realm.
04:23 Like this runs on Elasticsearch and AWS Lambda, which isn't behind your firewall, but is potentially private.
04:29 There's also PyPI server.
04:30 There's DevPy.
04:32 There's, I have this, I guess I have this one here twice just from two locations, but there's PyPI server and DevPy.
04:38 And those are interesting.
04:39 You can basically pip install those and set them up and run them behind the scenes.
04:43 But I still feel like you're, you're onto something that there's something more to do here.
04:48 Oh, there might be something less and I'm just missing it.
04:50 I mean, do I even need a, can I just throw a directory somewhere or something?
04:54 So.
04:55 Yeah, I know.
04:55 I feel like, you know, there's like GitHub Enterprise and things like that.
04:59 Like here's a really cool box that is GitHub for your, for your enterprise.
05:03 Maybe there's something like that for PyPI.
05:05 Maybe this is, these are good enough.
05:07 I don't know, but it seems like that's an interesting area, right?
05:10 Definitely.
05:10 Yeah.
05:11 So I got an email, we got an email from a listener who said, look, I'm really enjoying your podcast.
05:17 All the news that you find is great, but I'm kind of living in an RSS world.
05:22 And I feel like RSS is great, but it's, it's not really where all the news comes from.
05:28 Like, where do you guys get your news from?
05:29 So Brian, where do we get our news from?
05:31 Well, where we get it from, where you guys get it from, I think should be from pythonbytes.fm.
05:37 So this podcast, honestly, I did took a look.
05:42 We, I pay attention to Twitter, I pay attention to newsletters and Planet Python.
05:47 And so let's kind of go through these.
05:49 We put up the, in our show notes, love the links to both mine and Michael's Twitter accounts.
05:55 We don't really put out a lot of news on the Python Bytes, but maybe we should.
06:00 I don't know.
06:00 Yeah, we probably should.
06:01 I feel like we should probably tweet out at least our six items every week, right?
06:05 Yeah, definitely.
06:06 Yeah.
06:07 Yeah.
06:07 We should get on that.
06:08 Yeah, let's do that.
06:09 But there's a feed aggregator called planetpython.org, if you don't know about it already.
06:15 But it has a few different websites and it does sort of everything new that day, or I think
06:21 it's updated several times a day there.
06:23 And you can, so like my RSS reader just points to that.
06:27 I just pay attention to that.
06:29 Yeah.
06:29 There's a lot of great stuff there.
06:30 We didn't really order them in any particular order, but there's a few Python related newsletters.
06:36 There's Awesome Python.
06:37 There's Python Weekly, PyCorders Weekly, and Import Python.
06:41 There's four.
06:43 And I don't really, I don't know if I have a preference.
06:45 I just like scanning through all of them.
06:47 Those guys all have great stuff.
06:49 And every one of them has at least one unique thing each week.
06:53 So they're all worth subscribing to.
06:55 Yeah.
06:55 And I also like the second opinion because I, if one of the articles, if there's an article
07:00 or a new project or something that shows up on all four of them or all, or three out of
07:04 four, I probably should go read it.
07:06 So pay attention to that.
07:07 And then Reddit is, Reddit's used quite a lot by Python people and there's a Python subreddit
07:14 that's pretty good.
07:15 Yep.
07:16 And I threw in trending on GitHub.
07:18 So if you go to github.com/trending question mark L, I think it's L equals Python.
07:24 Yeah.
07:24 For language, it'll actually show you all the trending repositories that are primarily Python.
07:29 So that's pretty trick for things that people haven't discovered yet.
07:32 Yeah.
07:32 I haven't used that.
07:33 That's neat.
07:34 Yeah.
07:35 I'm not really hanging out on Reddit a lot.
07:37 So one of the things that I think is good to know about Reddit is that there's a couple
07:41 of filters at the top.
07:43 Like when you're looking at the interface, you can, it seems like a constant stream of information,
07:48 but there's ways to say, what's the interesting one, the top ones in the last week or the last
07:53 month or something that that's helpful to filter some of the stuff.
07:56 Yep.
07:57 Absolutely.
07:57 Well, let's move off of news and onto news.
08:01 It's very meta.
08:02 Yes.
08:03 So we've talked a lot about asynchronous programming, the concurrency story in Python.
08:09 And as we've said, this is for Python 3.4 and 3.5.
08:12 These are some of the really big changes and advantages to the newer versions of Python.
08:17 So what I wanted to highlight was something done by David Beasley.
08:20 He's done a bunch of great public speaking and teaching and stuff.
08:24 And he's created this project called Curio, the co-routine concurrency library for Python.
08:29 So this is a small little library built for performing concurrent IO and common system things such
08:37 as launching sub processes and farming out work on threads and process pools.
08:40 So it's built from the ground up to basically be taking full advantage of the programming paradigms,
08:50 things like async and await and Python 3.5.
08:52 And it doesn't have a lot of the baggage that comes from, say, like using Tornado or Twisted or something like that.
08:57 Pretty cool.
08:58 Okay.
08:58 I haven't looked at this, but I did want to see some good example of a production library
09:04 that uses async and await to try to understand that better.
09:07 Yeah.
09:08 He's got a really cool example of writing basically a socket-based server that can communicate with people
09:15 and handle thousands and thousands of concurrent requests using a single thread.
09:19 So the mental model for how it works, I think, should probably be a little bit like Node.js, right?
09:24 You sort of subscribe to some work and then you get a callback when that work is done,
09:29 like so when you get a message from a client or something.
09:31 But because it uses async and await, it looks basically like standard procedural non-concurrent code,
09:39 which is the way that code should look, right?
09:41 It's great.
09:41 Okay.
09:42 Cool.
09:42 Yeah.
09:42 So check that out if you are wanting to look at a take on async and await.
09:47 Yeah.
09:47 My last item is actually a – I got this through Reddit just the other day.
09:52 I was looking through the hot things from the last week on Reddit in Python.
09:56 And this item was Pandas is switching to use pytest as its test framework.
10:04 And I thought that was really cool because pytest is kind of something I like.
10:09 You should write a book on it.
10:10 Yeah, I should.
10:11 Yeah.
10:11 Yeah, that's really cool.
10:13 I think it's an interesting look at the challenges of moving like a very large, highly visible,
10:18 highly used project from one testing framework to the other.
10:22 And there was comments like in this GitHub thread, things like, well, pretty much everything moved over okay,
10:28 except for these 69 tests.
10:29 They really are hard.
10:31 And we need somebody to like champion taking on these 69 tests that just won't move.
10:36 That's just 69.
10:39 That seems like a lot of work.
10:40 Yeah.
10:41 They said many of the ones are running into challenges because of external resources like databases or other funky things like that.
10:49 Huh.
10:49 Okay.
10:50 Yeah.
10:50 Actually, external resources is the reason I chose pytest in the first place because I depend heavily on resources.
10:57 And it handles fixtures the best.
10:59 Anyway.
10:59 Yeah.
11:00 Awesome.
11:00 Yeah.
11:01 So very cool example.
11:02 All right.
11:03 So my last one is I kind of cheated and picked something that I did.
11:07 But I think this one is noteworthy given the amount of attention the community gave it.
11:13 So last week I had the honor of having Guido Van Rossum on Talk Python.
11:19 And we spent a little over an hour talking about how he got into programming.
11:23 What were the influences on the Python language?
11:26 There's a language called ABC that he was actually working on before Python.
11:30 Why did ABC fail and go away?
11:33 Why did Python succeed?
11:35 How are we doing on the move to Python 3?
11:37 What are his favorite features?
11:39 And even what he's up to at Dropbox these days.
11:41 So really, really interesting conversation looking backwards and forwards with the creator Python.
11:48 I really enjoyed that conversation, actually.
11:50 It's one of my favorite episodes now.
11:52 Yeah.
11:52 Thanks.
11:52 I really liked the discussion of the two versus three and both the reasons why they did it and also the difficulty.
12:01 And kind of a lot of people dragging their feet and not wanting to switch.
12:06 And there were real world reasons that just sort of hit them.
12:10 They didn't think about those.
12:11 It was a pretty interesting take.
12:13 I liked it.
12:14 Yeah.
12:14 I think people will learn a lot listening to Guido.
12:17 So I wanted to highlight that because I think Guido doesn't do a lot of those kind of open, ask me anything type things.
12:25 He does a lot of public speaking and stuff.
12:26 But I thought this was a great look inside.
12:29 And he was really a great guest.
12:31 And it was a lot of fun to talk with him.
12:32 So check that out.
12:33 Okay.
12:33 Great.
12:34 Well, that's our six picks for today.
12:36 Yeah.
12:37 So that's our six.
12:38 Yeah.
12:38 Yeah.
12:38 So that's the news for Monday, February 27th.
12:42 What else is going on?
12:43 You had a great episode with Mahmoud, a friend of the show, Mahmoud Hashemi.
12:47 That was actually like a month ago.
12:49 And I finally got it all edited and out.
12:52 I put this out last Sunday.
12:53 And so it's episode 27.
12:56 And it's a really good.
12:58 And I really enjoyed the discussion with him.
13:00 We started off with the excuse of talking about the different levels of testing, like unit versus system, stuff like that.
13:07 But we just talked about all sorts of stuff, testing related and Python related.
13:12 And the other excitement is the I released it on a new website.
13:17 So I have testandcode.com now running everything.
13:21 And it'll be on both websites for a while until I get everything switched over.
13:25 Yeah.
13:26 That's great.
13:26 I'm looking forward to listening to that episode with Mahmoud because he has great things to say.
13:30 I had him on to talk about Enterprise Python.
13:33 He works at PayPal and does a bunch of cool stuff with Python there.
13:37 So I'm sure that's really interesting.
13:39 That's great.
13:40 Well, he used to work at PayPal.
13:42 Oh, interesting.
13:43 Okay.
13:44 Well, see.
13:44 So you'll have to listen to episode 27.
13:46 Yeah.
13:47 Now I must listen to it.
13:48 Yeah.
13:49 Oh, my gosh.
13:49 I'm out of date.
13:50 Awesome.
13:51 Okay.
13:52 Well, that sounds very, very exciting.
13:53 And testing code, you finally unified the domain and the rename that you did a few months ago, six months ago, whatever it was.
14:00 Yeah, well, there's so that, yeah, testing code domain and the website now or the podcast and site have the same name.
14:07 So that's good.
14:08 Yeah.
14:08 Excellent.
14:08 And the book, the pytest book is out to reviewers.
14:13 I've got three chapters left to write, but we're chugging to head like a large freight train.
14:19 Yeah.
14:19 It looks like you're, are you ahead?
14:21 I know you were thinking like, geez, can I get this done by PyCon, which was end of May, but it feels like you're making good progress.
14:27 Yeah, we still, to actually get an in-print book would be a miracle at this point, but we are hoping to get a beta, e-book beta out by PyCon.
14:37 Awesome.
14:38 Okay.
14:38 Well, congratulations.
14:39 And I've seen some of the covers and they're both very cool.
14:42 So I'm looking forward to seeing which one you go with.
14:44 Yeah.
14:44 So how about you?
14:46 What's up with you?
14:46 You know, not a whole lot is going on with me right now.
14:49 I released my consuming HTTP services course and I'm just working on like two or three more courses.
14:55 I'm actually writing a Python article for Code Magazine.
14:57 So I'm supposed to submit that this week.
15:00 It's about celebrating the 3000th day birthday.
15:05 Nice.
15:06 Instead of birthday.
15:07 Of Python 3.
15:08 Because, right, just a few days ago, Python 3 was 3000 days old.
15:11 So that's pretty cool.
15:12 So Code Magazine, is that a print thing or?
15:14 Yeah, it's a print thing.
15:15 Cool.
15:15 I didn't know there were print code magazines anymore.
15:18 Some people still read them, I guess.
15:20 We'll see.
15:21 Yeah.
15:21 Okay.
15:22 Well, awesome.
15:23 It was fun talking with you today.
15:24 Yeah.
15:24 Thanks for sharing all the news.
15:26 Now people can go out and package their Python code up and hear Guido talk about it.
15:30 Yeah.
15:30 Great.
15:31 All right.
15:32 Well, good to see you.
15:33 Thanks, everyone, for listening in.
15:34 And we will catch you next week.
15:36 All right.
15:36 Thanks a lot.
15:37 Bye.
15:39 Thank you for listening to Python Bytes.
15:41 Follow the show on Twitter via at Python Bytes.
15:43 That's Python Bytes as in B-Y-T-E-S.
15:46 And get the full show notes at pythonbytes.fm.
15:50 If you have a news item you want featured, just visit pythonbytes.fm and send it our way.
15:54 We're always on the lookout for sharing something cool.
15:57 On behalf of myself and Brian Okken, this is Michael Kennedy.
16:00 Thank you for listening and sharing this podcast with your friends and colleagues.
 Overcast
        Overcast
     Apple
        Apple
     Castbox
        Castbox
     PocketCasts
        PocketCasts
     RSS
        RSS
     RadioPublic
        RadioPublic
     Spotify
        Spotify
     YouTube
        YouTube
    



 
        