Sheena is a long-time Django developer and teacher currently focused on Prelude Tech, small workshops focused on topics like Django, HTMX, and Git.
This episode was brought to you by Buttondown, the easiest way to start, send, and grow your email newsletter. New customers can save 50% off their first year with Buttondown using the coupon code DJANGO.
Carlton Gibson 0:00
This episode is brought to you by Buttondown, the easiest way to start send and grow your email newsletter.
Will Vincent 0:11
Hi. Welcome to Django chat podcast on the Django web framework. I'm Will Vincent, joined by Carlton Gibson, hello, Carlton.
Hello, Will Vincent.
And we're very pleased to welcome back. Sheena O'Connell, to talk about Django, education technology and all those things. Welcome Sheena.
Sheena O'Connell 0:27
Hey. Thanks. Glad to be back.
Carlton Gibson 0:29
Glad to have you. Sheena. Thank you for coming back on.
Will Vincent 0:31
So last time you were at a startup, amoozi focused on education and technology, and you since moved on from there, but are still very involved with both education and technology. So maybe I let you say, What? What are you up to these days? Awesome,
Sheena O'Connell 0:43
yeah, so it's more like it wasn't really a startup. It was a nonprofit in South Africa that finds high potential youth and trains them. And there's many wholesome things about that. So over there, I was doing some technology stuff, built a learning platform that worked pretty well and taught a bunch of people stuff, and that was cool. Now I am trying to take everything that I've learned from there, and I'm kind of green, fielding it a little bit, and trying to start something new from scratch, and that's terrifying, but also a lot of fun. So I've got two main things that I'm working on. The one is Prelude, which is a training company, so I've already gone through a couple of different iterations of like how to craft this thing and what to focus on, but my main thing at the moment is running workshops that are focused on Python and Django related things. So the most popular one is like how to build a modern front end using Django, so it's got HTML and tailwind and alpine and playwright, and just introduces people to all of these things, and like how they plug in together and get some working on it. And that's that's been pretty cool. People are digging that. And then I've got, like, another one on Git, because everybody knows somebody who's struggling on Git, everyone, and, like, a few other things. So it's Prelude. And then, yeah,
Carlton Gibson 2:19
I want to jump in. I want to talk about this thing. So would you want to tell us the other bit first and then? Or would, should we just jump in? Let's talk. Let's talk about those because I somebody emailed me and was raving about your Django front end work. Thank you. They were, like, effusive about how good it was. And so I've heard amazing things. I'm obviously super excited. So you say Django, you say Alpine, say HTML, using playwright. Oh, this, this is where the park is, yeah, yeah, yeah. It's,
Sheena O'Connell 2:47
it's super fun. Like, people, yeah, the people who showed up so far have been, like, really, really engaged. It's been very, like, it's quite an intense workshop, because it's, like, recovering a lot of stuff, and it's over a weekend, so I'm trying to do it over weekends, or, like, not office hours, so that people who are maybe transitioning into tech, they don't necessarily need to quit their day job, day job, or take a whole lot of leave to take part. So, like, there's a lot that happens in a short amount of time, and super intense and a lot of interaction with people. And by the end, I'm like, a little bit sad, because I'm like, Oh, you guys are all leaving, yeah. So, so it's super fun.
Carlton Gibson 3:27
So how, how? What level? What level do you have? So you say, transitioning into tech. So is this assuming no background Python or some, no,
Sheena O'Connell 3:35
not, not necessarily, some, some background in Python is very helpful. So I don't want to. So I have had people show up who haven't used Django before, and they sometimes struggle a little bit because, you know, Django has views and models and URLs and templates and it's got all this stuff, and they're like, where do I put my code? And so if they're learning Django and all the stuff at the same time, then it can be a bit heavy. Some people can do it. Some people struggle. So I do have a more like basic Django course as well. That is like almost a precursor, like people can do it as a precursor, but it's it's not as popular because just learning Django isn't as like fancy.
Carlton Gibson 4:17
I just on that tech stack, that choice of valpine and HD Mexicano. I find it really powerful and really not just powerful. I find it empowering as an individual developer to be able to do so much. How, yeah, yeah, how your people find
Sheena O'Connell 4:33
so far, they've been finding it pretty, pretty good. I so part of the my thinking on these workshops is you can only do so much in a weekend, but what I can do is I can plant a bunch of seeds, and I can set those seeds up to grow a little bit. So after the workshop, I get feedback from people about what they're doing with it. And like during the workshop, they come up with projects that they want to work on, and like most people, continue with their projects, which is cool, sometimes it's work project. Sometimes. Portfolio projects, but they're like, leaning into their tech, into the technologies, and actually using them, which is awesome.
Carlton Gibson 5:08
Yeah, I'm a big fan of having a portfolio, having a little project that you just keep going, keep tweaking, keep playing with. It's, yeah, you know, it's
Sheena O'Connell 5:16
a test, like, it's great, like, to get people to go deep into a technology, because a lot of folks who are learning web development get stuck in tutorial hell. And they'll learn a bit of this, and they'll learn a bit of that, and they'll always, like, go down these golden pathways that have been laid out for them. And like, real like, real development isn't about following somebody else's golden pathway. You have to get off the beaten track and, like, build stuff for yourself and bump your head and go deep, deep and get frustrated and overcome the stuff, the stuff. So, like, a proper portfolio, it doesn't just demonstrate the technical skills it shows. Actually, you've got the grit to do this job it takes, because that takes that. So, yeah, big, big fan of portfolios, no,
Carlton Gibson 6:01
and that's that point about grit, I think is perfect, because as a as a prospective employer, you're looking for someone who can solve the problem on, you know, Thursday, and it's turning out difficult, you know, are they able to keep pushing through to the solution? That's super Yeah, yeah. Can I ask about playwright quickly? I'm Will. I'm not letting you speak for ages. No go. I'm just too excited. So I I've spent ages. I've been I was scarred by selenium as a young developer, and have battled it for many years, and I've been putting off. I've been playing with all sorts of things, Cyprus and jest and Vitesse and all of these other which aren't really what I need. I need playwright, but I mean, a bit scared. And then Simon Willison said that it's, you know, it really is the thing, and I should give it a go. So can I get, you know, that's almost enough to push me over then. But what's your take on playwright?
Sheena O'Connell 6:52
I was also a bit skeptical of it at first, because there are so many different like front end testing frameworks and tools out there, and there is a bit of fatigue in that space. The thing that actually got me excited about playwright was a talk I saw a DjangoCon 2023, I think from he calls himself a testing Panda, or something like that.
Will Vincent 7:17
Yeah.
Sheena O'Connell 7:19
And I really enjoyed that talk, like he he wrote things down. He was like, here are the pros and cons, and this is why I've chosen this. And I was like, That makes a lot of sense for me. So it's super easy to write playwright code. It does a lot of like, like, if you're writing like, pure selenium code, then the code becomes pretty brittle.
Carlton Gibson 7:38
Yeah. Really pressure. Yeah, yeah.
Sheena O'Connell 7:41
Because a lot of the time it's just about timing. So if you click a button on a website, the response, like the reaction to that isn't always immediate, because it'll be fetching data from the back end and doing stuff, and then you end up, like, having your code littered with all of this, like, time, dot, sleep, what, what? Statements, and it just ends up being, like, hard to see the logic, and it's hard to that. And if something just like, randomly breaks, and you're like, what could it be? Maybe if I make this wait even longer, then it'll work, and it's, yeah, you just end up fighting the thing. Playwright has a lot of stuff built in that does that fighting for you. So it'll, like, check things in a loop and have sensible timeouts and things like that. But it's also really nice because it's got, like, it's built for testing, so it's got different assertions and expectations built in, which is great. And probably my favorite thing is it's got a code generator, so remembering how to access every piece of the page through playwright is kind of a pain in the neck. You don't want to have to, like, like, checking the docs all the time is very possible, but it's kind of a pain. So what you can do is you can spin up this thing called cogen and point it to a URL, and then you can interact with the web page, and it'll write code to match your interactions. And then you can take that and turn it into a test. And this is super, super cool. If you've got, like, a bug or something in your front end, you can literally go and demonstrate the bug to yourself, and then that'll turn into a test. And then you can, you can just be like, okay, instead of asserting that this thing has a value, assert that it's empty and and then you go and fix your code and the regression doesn't happen. Yeah, it's fantastic. I like it so much. That
Carlton Gibson 9:32
sounds like so you've encouraged me. So between you and Simon, I might pluck up the courage and mark up do it.
Sheena O'Connell 9:41
It's super easy as well. So, yeah, very, very easy to get ramped up. The one thing to know is that if you're using it, then you have to use PYtest, which is fine, yeah, because it's got all sorts of pi test tooling, but it doesn't have the same for unit test, and you'd have. Do jump through some jump through some hoops to make it work nicely. Okay, we can,
Carlton Gibson 10:04
perhaps, we can perhaps cope with that before, before I let will speak again. I want to ask you about your Git. Yes, because I kind of feel that Git is sort of developer literacy basic. Yes, it's essential.
Sheena O'Connell 10:18
Yeah, it is. It really is. So I created it because I saw a need. Like a lot of people, when they're learning to code, they just learn some basic commands, and they're like this sort of seems to push the code over there, or they drag and drop to upload their stuff into GitHub. That also happens a lot, and it's not like a fun, fashionable skill, it's just this weird chore that people have to do. So they're not excited about learning it. And then on top of that, like, so when I, when I ran my Django modern front end course, like, I pay attention to what people are struggling with and what they need and get came up as a thing that a couple of people were struggling with. Was like, okay, cool. They like, we actually need a course on this. They need to focus on this. And there's a bit to it. And I've also spent time just talking to people who work for like, consultancies and whatnot. And I was chatting to a friend of mine recently, for example, and he was ranting about how his co workers are still naming things like version one version two, and so like, even people who like, are not beginners, are still struggling with Git, and it's like, it is weird, but it's not actually that hard. Like, it's it's weird until it's hard, until you, like, grasp what the graph is doing, like, what the commit graph is doing, and what the different commands do to the Git graph. And then once you once you know the graph, and you know how to, like, look at it and interrogate it, then you're like, oh, actually, this is, this is fairly straightforward for the most part. So yeah, so that was the thinking behind it. And so this, course, that I've made, it's just one day long, and it's still, like, quite a quite a long day, but it covers again, like understanding the the commit graph, like how to how to commit things, how merging and branching work, dealing with remotes, dealing with merge conflicts, because that that always like breaks people's heads the first time you like
Carlton Gibson 12:15
that, that's when you delete your get repo and re, clone it right At that point.
Sheena O'Connell 12:19
Yeah, yeah, there's a lot of that I did that once rebase
Will Vincent 12:27
too, right? I feel like rebase is one of those ones, like, you feel like you're comfortable, and then someone's like, what about rebase? And there is a little, what is your take, right? Isn't there still some argument on what you know, how much you should use rebase or not? Yeah, so
Sheena O'Connell 12:43
I, I would go with whatever, like the the team is using already most of the time. I like rebase because you do get that linear history. But sometimes, if you rebase a thing like, you just end up having to deal with lots of merge conflicts, like in a row, like, oh another one, oh another one. And it ends up being, like, a lot of work and confusion just to have, like, a tidy looking branch structure. And so I'm not, like, I'm a fan of it when it's clean and when it just works, but when you have to, like, really hit it with a hammer to make it work, then I'm like, I don't know if it's really adding that much benefits? Yeah.
Carlton Gibson 13:21
I think when, when you've got a country contributor who perhaps can't, doesn't know how to do it, sometimes it's easier just to say, no, do you just keep pushing commits and we'll sort this out at the end for the way we want, rather than Yeah, somebody who hasn't got the skills, and then saying, oh, and can you learn get rebases And then let's not do that. Yeah?
Sheena O'Connell 13:38
Yeah. You don't want to give people extra stumbling blocks if you're trying to get some good out of them, and just be like, here, do this really frustrating thing. Yeah, that's the price of entry here. Yes, show us your grit.
Will Vincent 13:53
It's a tough thing because you kind of have to be doing it live or on a real thing to really focus on it, right? And so by nature, you're going to be, I mean, I don't know how your workshop is done. Like, you almost need, like, a, you know, like, like a Git games, like, they used to have those, like this, kind of, like, capture the flag for, like, security things, right? I know there's, I think there are things like this for get but generally, you're like, Oh, dang, I need to, like, put this code somewhere. And then, yeah, you're, so you're doing it on the fly, and then, and the same time you're dealing with, you know, a Django fellow who lives in it, yeah. So I always think of that with production too. Production is hard to teach people, because you can, okay, local Django, but then production, yeah, just like, this whole world of, like, it's so different, and then it's, it's live, so you don't necessarily want to mess it up. And then, yeah. And then if you've ever, like, you know, if you mentioned staging servers to newcomers, their head is just like, they're like, I quit. Like, I can't even wrap my head around, you know, like, my, my local database, my production database, weight, they're different. Like, yeah. And then you say staging, it's just, like, blows their head, yeah.
Sheena O'Connell 14:56
It's tricky. It's like, so you always want to, I. And build up to things over time, I find so even with the with the front end, course, like, like, give a person a thing to learn and get, let them practice that, then give them like a slightly harder thing, or like a slightly different thing, and try to keep them like, in the zone of proximal development. So you try and keep the like, if it's too easy, it's boring, if it's too hard, then they're just like, well, I'm stepping away. And, yeah, keeping it in that zone is a little bit of an art form, but it can be done, but it takes some iteration. Yeah,
Will Vincent 15:34
and is also there's that disconnect between what an individual or a small team does and what a big team does. And most of the people who have the time, or take the time, or take the time to write, right? They say, this is how my team does it, you know? Because, yeah, I run sites that collect money. I don't have a staging server, you know. I'm not even using Docker for it anymore, you know. But if I had a bunch so that, so it's so it's both the combination of what is out there, right? Like, oh, you need interactive jump to react. You know, that was the thing back in the day, yeah? But then also, yeah, if you're doing it your own way, do you write it up and then? And maybe there's even more variety, right? Like, I know Carlton, Carlton and I do our stuff very differently. I've
Carlton Gibson 16:19
just didn't know how I used to do it 20 years ago, and I've just kept doing it. So, yeah, ago, and
Will Vincent 16:24
I've just kept doing it. I'm not just a little bit, little bit newer, but I'm still probably old with, you know, yeah, there's so I can see, especially in a workshop, when someone has one of these things, they can, you know, raise their hand or whatever, and you can help them get past this thing of like, oh, do I focus on this? Do I not focus on this? Okay, I'm stuck, because so much is, I think, to get out of the tutorial. Thing is, yeah, is asking for help and doing it in a way that, like, you know, if you have to ask to a forum like the Django forum, right? People ask questions there, they should use it. It's great, but you don't always get a great response, because you have to ask a good question. And also, if you have to wait a day or two or three, you're kind of right blocked, yeah, whereas if you're actually in a workshop with someone who can, who can help you immediately, yeah, yeah, then you can keep the momentum going. I think a lot more, yeah. I think that's very powerful.
Sheena O'Connell 17:15
That's one of the pieces of feedback that I got is, like, the the human interaction is the thing that, like, the contents are solid, the skills that they're learning are solid, but the human interaction makes it a bit more like, like, this magical experience so, so
Will Vincent 17:30
And for you, and for you too, right? To think about, yeah, or to think about the things you already know that we don't think about, right? I mean, that's the the curse of experiences. We're just dealing with our own problems, and you just completely take for even I do this, and even I say, even, even though I email with readers and stuff, there's still things. I'm like, Oh, is that is that hard? Is that complicated? Like, because I just, I just done it so many times now, so I need those reminders. And
Sheena O'Connell 17:57
yeah, I get you like, it's so surprising. Sometimes, some of the things that people get confused about, I'll give you some examples, like, so I had a workshop where one of the people was really, like, putting files in weird places. And like, if there was an instruction to put this in the root directory, directory, it was, like, almost random where it ended up, and then it turned out they needed to know what the root directory was and like, so when I noticed, I tried explain, try to explain it once. I'm like, Okay, that didn't land. So the other thing that's kind of cool is sometimes a person will try to help a person once, and then they'll be like, I've done my job. And they'll like, go off and do something else. But in a teaching situation, it's almost like it's a challenge for the teacher to be like, how do I make this land? I tried to explain it this way, and it didn't let me try again. And then she Yeah, and then they got it, and life was good, and they were very, very happy that now they have this concept that has been bugging them since they started to code. And another one that happened, so I ran around that workshop again last weekend, and there was one guy who was like, let me tell you what I want to want to see from HTML, cool. Tell me I want to see and he brings up his VS code. He was like, this is cool thing that react does. Let me show you. Brings up his VS code. He opens a React project, and he's got tailwind installed in his react project, and he starts, like, writing our tailwind classes, and it auto completes. He's like, this is something react does I want hmx to do that? It's like, okay, we're gonna have to dig deep. Now.
Will Vincent 19:37
It's all magic. It's all magic. Yeah,
Sheena O'Connell 19:40
yeah. So it's like, very surprising sometimes, what people bring, what people like, conflict,
Will Vincent 19:49
yeah, yeah. I like Carl, sorry, Carlton, I'll say one thing and then let you go. I was just saying I hear you on the root level, project level, because I've rewritten this. Yeah, every time I go through updates in my book, because I know people get stuck because so now I try to, I think I try to be consistent with project level, but I will do the like the tree. I'll visually show the tree of like, Yeah, this is what it needs to look like. And it gets harder as the project size grows, but especially early on. You know, for a static directory, like, project level, easy to say, but like, I need to be like, and it should look exactly like, yeah. So the treat the tree command works, right? Because I get it that they're like, I'm in an app, like, where they put things outside of settings, you know? Because maybe they didn't put the period when they did start projects and they have another directory, and yeah. And then they're like, yeah. Like, hey, will, like, the official polls tutorial does it differently than you do it like, what's up with that? And it's sort of like, well, wind me up with my thoughts. But I there should be, I should do a talk on like, things, you know, things that are different and like, half matter. Half don't matter. Let me just tell you, yeah, that's
Sheena O'Connell 20:55
tricky as well. Because when you say, like, do it like this, and they're like, We must always do it like this forever. A lot of times, like, oh, I need to tell you about the nuance. I need to hint at it at least. And be like, there are other ways, but we're doing it like this for reasons, and then you end up having something that's like, really, really long. So it's so totally right.
Will Vincent 21:13
Like, someone asked you a simple question, and you're like, Well, how do, how deep do I go here? Because, like, what is, what is? What do you need to know to go to the next spot without, you know, misrepresenting something, but sort of being like, focus here. Don't focus there, and
Sheena O'Connell 21:27
how much of it should really be in the in the content. So, like, you write books, and books are long, and if you like, try and solve everybody's problems, they would be really, really, really long, and probably would also bore a few people, because we'd have a whole lot of details that they don't know. So it's like, where's the sweet spot of like, how much information to put in the main thing, and how much to like, and how do you support people with the rest of it? And that's that's tough to do with like content. That's another reason why I quite like teaching people in a human way. It's like, like, you need good content. You need freaking good content, because otherwise Everybody has problems and you have to help them all, and it sucks and it's painful, but, but there's always like, these weird little rabbit holes and sub quests that people need to go on. And if you can just, like, be there to be like, Oh, cool. You actually need this other resource. Let me just help you specifically with the thing that you need. Then that's pretty, pretty powerful. Yeah,
Will Vincent 22:26
it's hard to scale that. I mean, it's amazing you've I'm not, I'm not surprised that there's demand for someone who's knowledgeable and a good teacher to do this. It's, it's sort of, when I've thought about this, it's like the 1% of teaching time, like, no problem, it's the other 99% right? Of like, finding people, updating stuff, right? Like, yeah, I imagine that's the same case, right? You're like, I want to focus on this one thing, but it's all this, all the other, all the other craft and figuring out, you know, okay, it works with five people. Does it work with 20? Like, what's the sweet spot of of that? I mean, I imagine you're still, you're still iterating on that, right? I mean, it's sort of like the three of us, if somebody was like, you know, volunteer or like, here's money, just like, parachute us into a situation. Be like, let's just fire off answers. But it's not that simple, assuming we even know the answers, you know, too. Sometimes it's like, Well, watch me stumble around,
Sheena O'Connell 23:17
yeah, yeah. So yeah. Sometimes there are a lot of, like, left field questions, but I think that's okay as well. Like, the tech changes all the time, and sometimes people will ask about a technology or technique. They're like, I don't actually know. And that's that's cool as well, because then I can go and find out about the thing and see if it is relevant and make some suggestions about it. But I think the other thing about building an education provider organization is it's like, yeah, there's all this extra stuff that you need to do that like you were alluding to, like, what is the system? What is the product? How do you market this thing? Like, my, my primary skill sets are like, software development and teaching. Like, those are the things that I'm that I'm really good at. And I'm like, okay, marketing,
Will Vincent 24:07
you have an email you have an email newsletter now, like, I get it right. Do the plug. How can aside from podcasts, where should people go to be informed?
Sheena O'Connell 24:15
So I do email people, but I try not to be like, it's so tricky as well, because I don't want to be spammy. And I be spammy, and I don't want to always say, like, buy my stuff. Buy my stuff. And I hope that the people that are listening to me at the moment are forgiving the spaminess because, because I'm sure I've annoyed some people, I'm pretty certain
Carlton Gibson 24:36
I don't buy that. Sorry. Like Eric Mantis was said this the other a while back as well. He's like, Oh, I feel embarrassed to post my stuff. No, no, Eric, we want to know about yourself. And the same with you, shiny. We want to know what you're up to. It's, you know, people and people who don't like it, they can just filter that. They can just turn away. Yeah,
Sheena O'Connell 24:52
that's true. Yeah, that's true. I could just use, like, a specific hashtag and be like, if you don't ever want to buy my courses, just filter that out. And then you're good. But yeah, like, whenever I have a new thing, I post on like Mastodon and Twitter and LinkedIn at the moment, and I think I should probably do blue sky as well. People have been telling me that I should be there so more, more social media stuff. Automations help, because otherwise I would drown in social media.
Will Vincent 25:22
I should, I should, I should set some up. I guess Zapier, right? Like I was, Zapier is
Sheena O'Connell 25:27
a thing. I've been using buffer, and that's quite nice.
Will Vincent 25:31
Buffer, yeah, buffer, Oh,
Sheena O'Connell 25:34
yeah. So it just lets you schedule stuff for multiple channels. So I found it very, very helpful. Yeah,
Will Vincent 25:46
there you go. I learned something.
Carlton Gibson 25:48
Okay, so I want to butt back in with a slightly separate question. Then we should swing back to you, to the second thing you was on your agenda, and then we'll cut back. I know we'll absolutely cut back to the education topics, but just while I've got you on this very narrow topic of Django front end, is there anything given? Because people have always been like, Oh, can we integrate with this framework or that framework or that? And Django has always resisted that because it's a more it doesn't want to tie itself to react, for instance, yeah. But then the Alpine and HTML type things, they're very simple in their you know, just the script tag and whatnot. But from your from your current work, from your workshops, from what you're seeing, is this something that Django could be doing to that, you think, for the for the static, that static files, story that you're like, Do you know what we had that that would be a big, big improvement?
Sheena O'Connell 26:36
Um, yeah, I think, like, sometimes you need to install Node modules and they should go somewhere. So like, with tailwind, I know that there are some Django tailwind things that exist that you can just install and use. I was showing people how to sort of do it by hand and by scratch. So like, how to use the tailwind CLI in the context of a Django app. And how do you configure your stuff, but it's, like, it feels a bit messy. So I think that's the thing. And just like, I know, even if you wanted to use something not tell and like, if you wanted to use Bootstrap or font awesome or anything, you need to, like, npm install it, and it goes into your node modules, and then you need to, like, know, to move it to your static files in a certain way and go. So there was, like, a solution for that. It would be cool. I think that's the main thing. Okay, interesting,
Will Vincent 27:30
but that's sort of a canonical problem. Is you're like, I want to use this tool, but I don't want to do a course on this tool, but installing this tool sort of requires a whole course, and you have to be like, just do it this way. It works. I don't want to answer questions on it because I want to focus on something else. But then again, someone's brain is kind of, that's why, like, I still remember I had in graduate school, I had a professor for accounting of all classes, and people would throw all these questions at him, and he was great, because he answered every question. But he would be like, as an aside, so he would just sort of say, like, Okay, this is, like, what you need to know, and this is I'm gonna answer it. And that was so helpful. Because sometimes, you know, sometimes, if you're overwhelmed, you're like, I just like, I'm gonna check out right now. And so that was people coming with different like, in that case, you had people who are totally new to accounting, and then you had people doing it professionally for years. So I thought that was a really elegant way of not saying no, but just making very clear like, this is, this is the path we're on, and this is not so people could sort of self choose how, how much they wanted to process what you say. This
Carlton Gibson 28:35
episode is brought to you by button down. That's buttondown.com. Email software for developers like you, there are hundreds of email marketing software services out there, and they will pretty much offer the same thing, collect and clean addresses, send out broadcasts or drip campaigns, get analytics so you can see what's resonating and what's not. Button down is designed to hook into the tools that you already care about, everything from static site generators like Jekyll or Hugo to payment platforms like Stripe and memberful, you can hook your site up to button down with just a form element or a simple REST call write emails in Markdown and then get on with the actual work you're supposed to do. New Customers can save 50% off their first year with button down using the coupon code Django, and if you email support, they'll white glove migrate your existing subscribers and archives for free.
Sheena O'Connell 29:22
That's really nice. Yeah, I think, like maintaining a good signal to noise ratio is part of that, and just being like, okay, relevant, not relevant, or relevant and nice. And then the other thing, I think, is just giving students a bit of agency. And that's quite a big deal. So like with my workshops, I found that one way to keep people like, generally speaking, if you want to keep a person motivated, you want to give them some agency and give them some choice in what they're doing. And so if the workshop is like, Do this, do this, do this, do this. Then, like, some people will just like, start going through the motions or check out. But if you're like, cool, do these things. And then if you want to, here's a side quest, and it's cool. These reasons, and you can do it if you feel like it, or you can move on, or you can do it later. And just littering the thing with side quests has been really nice. Like most people do most of the side quests, but it does give that distinction. And like people have commented that, that they really enjoy the fact that they get to that they get to do these things. So that's been quite fun. Yeah,
Will Vincent 30:22
I love that. The phrase side quest, I feel like I've seen it in mass culture more and more now, like, because it is such a great way to Yeah, like the extra things that if you're so inclined, yeah, yeah. Since you know, react, writing code for you, how do you talk, I want to ask about AI and llms, but before that, how do you what? How do you approach text editors? Because, you know, there's everything from like, kind of, Do it all for you, and then there's, you know, super basic, like, alright, so I guess, I guess I'll ask a two part, what do you see people using, and what do you recommend to them? Because that is a very wide spectrum that's out there.
Sheena O'Connell 31:02
So a lot of the time VS code. Like, VS code is very, very popular. And one of the things that I like about VS code is the fact that it uses, like, you can use it for whatever language you want, which is nice. It's not like, glued to one thing, because I do switch languages sometimes, and it's nice to not have to just like, switch to a different tool completely. So that's that I kind of like things that are not super opinionated. I don't like things that make assumptions for me and write the code for me too much, because I'm like, what's actually happening back there? Like, like, it's nicer to understand. And then I suppose the other question is around llms in these things, which is, don't go down that rabbit hole. It's a deep one. So I
Will Vincent 31:49
would love to, if you're up for it. Yeah, yeah. So
Sheena O'Connell 31:53
personally, I like, I haven't used a lot of different ones for writing code. I because I'm one on VS code. I've used copilot a lot, but I often find it disruptive and then end up turning it off. So I find like, with code that is quite obvious, then like it makes good suggestions and speeds me up. But a lot of the time, if I'm if I'm doing something novel, then it gives me very weird and distracting suggestions, and then I turn it off. I think in our last discussion, the last one we had Carlton, you said using co pilot is like pair programming with the drunk person. Yeah, I think that was, I think that's a Carlton
Carlton Gibson 32:38
quote. I remember that sounds like something I would have
Will Vincent 32:40
said that should be on their website. That's the tagline, really, is that thing you just
Carlton Gibson 32:46
said about when you're thinking about something difficult and you're just trying to think through the problem, and then all of a sudden it's put these three lines of junk there, and you're like, No, go away with the three lines of junk. I'm trying to think now, and it's knowing when to just switch that thing off?
Sheena O'Connell 33:01
Yeah, switching it off is important. And, like, I've even found I know, like, let's say you want to write some Django models quickly for a fairly well known problem. So the ticketing system I am using is not appropriate, and I would like a different one. So I'm like, Cool, maybe I should make one. And so I was like, hey, like, make me some models for a ticketing system. And it was just like, scope creep. All of it, all of the scope creep. It's like, it won't necessarily go for the simplest version of what you want. It'll go for like, the fanciest, most complicated thing. Often, like, if I use, like, an LLM chat situation to generate code, if I'm like, I'm not actually show how to do this, show me how to do this. Then it'll often come up with something really complicated and weird. And then I'll say, like, okay, simplify it. Simplify it, simplify it. And then it'll be something I'm like, okay, that actually looks like it'll work. So, yeah, you got to do things with, like, a major spoonful of salt. In my experience so far, like, every now and again, I try again, and then I get tired of it and back out.
Carlton Gibson 34:06
It's still learning how to do its thing, right, and the tool developers are still learning how to integrate that. Yeah,
Sheena O'Connell 34:12
definitely. I mean, it's definitely, like, upward trending. It's definitely getting better. Yeah,
Will Vincent 34:18
yeah. I mean, I'm, I think I, I say, I think I mentioned this publicly. So I've, I've just joined JetBrains, the developer advocate who makes pie charm and some other text editors. So I'm, I'm very deep, or getting deeper, into this world. And like this morning I was going through, there's some new features coming out, and it's definitely a thing. I think it's just interesting to see where, where the boundaries are. Because to me, there's a newcomer can just write a couple lines of code and have a, you know, ticketing Django website, but they have no idea what it does. And, you know, it's not 100% how any of us would do it. And so I feel like, in a way, that makes it harder to learn, because it's so easy. You take a slop given to you. Yeah, not that I want to be like, you have to do it manual for everything, but it's there's just the total lack of curation out there at the same time for the last year or two, I think spurred a lot by Jeff Triplett and some other people like, I use it all the time as a, again, a drunken coding partner, where I have context, and I'm, I'm like, oh, you know, I want ideas basically, like, how would you do this thing? And I've got learned how to be, you know, how to ask it to, like, improve things or remove stuff. So I find it really helpful for idea generation. But I, you know, to go the next step, which some some code editors already do have just like, write the prompt and it does all the code for you. It seems very hard for me, in a Django context, for that to work, like maybe for tests. It could work for front end. I think it works actually pretty well, because you can see it. But you know something around billing or something else you know where you kind of really want to, A, have it be correct, and B, know what's going on. Yeah. It's almost like, you know, you want a pistol and you given a bazooka. Oh, yeah, yeah, definitely. But it's definitely, it's definitely the thing. And then I'll just last stream of consciousness thought, I also it's very interesting to me, the context in which it can be used. And by that, I mean a lot of people at work. People at work are not allowed to use a public facing LLM, right? So, so some people are like, no. LLM, some people are like, give everything to chat GPT or Claude or whomever, and then these local models like llama from Facebook and stuff, you know. So there are text editors that can and ways you can work with that, right? Like, it's a little clunky now, but that's going to be pretty smooth very soon, if it isn't already. So it seems like there's these three stages of how you use it, how much public, and then the whole education piece around, how should you use it? So, for So, for anyone who asked me, I'm like, do not ask it to just like, do some huge, mega task, like ask it very specific questions and treat it as a drunken coding partner. Anyway, so that's, that's everything I have to say on that topic. I'm curious what you do.
Carlton Gibson 37:13
Just pick up the last bit, and I'm going to point it to you. Sheena, like it's that learning thing that works me. So I'm quite an experienced old hand now, and, you know, fingers creak a bit, so to have some faster auto complete, that's super but
Will Vincent 37:25
you're a month away from a neck here. Yeah, exactly,
Carlton Gibson 37:28
you know, but so for me, it's, it's great, and it's foibles I can, I can work around, and I can use it when I want to, and not I, I what I worry basically, about a junior picking up an LLM, and how are they going to get the sort of deeper understanding that you need to really solve the harder problems?
Sheena O'Connell 37:48
Yeah, I get you. That is a huge, huge deal. A lot of people use it as a crutch when they're starting to learn to code, and then they don't learn the main lessons. And I think, like, I've been trying to figure out how to best explain, like, why it's wrong to rely on an LLM too much while you're learning and like, let's say you're learning a language, like Italian. And when you start learning this language, it's not like, you'll start off by translating one word and then translating like, small groups of words, and, you know, llms can do that better than you and but, but your goal isn't to be a translation service. Your goal is to be able to have conversations and do like bigger things and like people when they're learning to code, when they start learning to code, they act as a translation service, because you like, give them these little, these little, tiny problems to solve, and then they solve them. And you're like, Well done, you. But they often come to the conclusion that that is what coding is. And look, these llms can do it better than me. And honestly, like becoming code literate is the easiest part of becoming a software developer, the hard part happens later. When you take what you've learned, you take your words and your sentences and you combine them into something much bigger and much more complicated with other people. And that's like, if you don't nail these foundational skills, you just don't get that. And like, the other aspect of it is, like, cool. We can write prompts to write code that works in certain situations. That's great. And we can write prompts in English. English is a blunt instrument compared to code. It's like, the most precise way you can describe what a machine should do is in the code, it's not in English. And there are many problems that you can describe, many algorithms you can describe in English, and then we can spit out the code, and that's great. But like, there are many that you can't and like, if English was as precise as we would like it to be, lawyers wouldn't be a thing. You know. Yeah.
Carlton Gibson 40:00
But also, quite often, even as good as a spec, as you write, you don't really know what the algorithm is until you Yeah, write it, and then you've got, that's your proof, right? The implementation is the proof. Like, yeah, yeah, that is
Will Vincent 40:13
Yeah, and it's gonna vary because it's non deterministic. Like, that's the other piece, yeah. So it's unreliable, and, yeah, it's different all the time. And, and the wild thing is another, while everything's wild to me today, another, like, I've had a chance to actually talk to a bunch of AI startups recently. And, you know, any AI startup is like, I'm gonna, you know, take, take crednoth and, like, send prompts to chat GPT and, boom, I'm an AI startup. That's kinda, I'm not even exaggerating. That's like, if you actually talk to these people at like, a bar, that's what they're doing. And they're daisy chaining all these prompts together that like, kind of sort of work. So then a it's wildly loosey goosey versus versus, you know, again, it's English. It's not code, and then they're also tied to the specific model. So you have a vision someone, someone down, down the hall for me, who's at a very well funded healthcare startup with millions of dollars, you know that they've got certain commands that work with, like, you know, 3.1 which is different than 3.3 and you just don't want to, like, touch any of it, because as soon as you do, it's like, yeah,
Sheena O'Connell 41:22
yeah. And that's something different, or just, like, swap the sentences around in some way, and yeah,
Will Vincent 41:27
but that's the thing, like, you know, we as developers, if you talk to, like, I just recently went to this startup thing here in Boston, and there was, you know, there's a lot of people with money who aren't technical and then a few technical people. And you talk to the non technical people, and they're, they're amazing evangelists for what, for what all this can do, right? But, like, practically speaking, everyone is has a CRUD and auth, something that is just sending English daisy chain prompts to chat GPT, and that gets them five to 10 million in funding, and they're like, this is all, oh my god, so fragile. And, yikes. Oh yeah. And
Sheena O'Connell 42:06
a lot of that stuff is often something that you could do in regular code,
Will Vincent 42:10
but yes, and it's not the same answer. So if, like, I'm yeah, you know, is this insurance company or whatever, or cardiologist, you know, like all the big hospitals here, they're using it. I remember one of them was bragging to me about he's at MGH Mass General Hospital, which is one of the top hospitals in the world. And he's like, Yeah, we have our internal LLM for data. And I was like, Well, how do you handle the fact that it gives you different results for the same prompt, like, guaranteed? And he was like, Huh? I don't know. I could ask our developers. I'm like, Well, I'm curious what they say too.
Carlton Gibson 42:43
I hadn't heard that analogy. Will of crud North plus llms, because
Will Vincent 42:49
that just came up. No,
Carlton Gibson 42:50
but that's the startup model now. But that is what it is. You go back half a dozen years. We'll take 10 years. The startup model was crud North plus Twilio. It's gonna wrap something around Twilio, and there we are. And now it's like, we're gonna wrap something around, oh, you know, chat, GDP.
Will Vincent 43:07
There was another Sheena's point. Often you don't need it for it, is the thing. Like, sometimes you do, but a lot of it you could have done, but
Sheena O'Connell 43:14
you get more funding if you make your product a little bit more brittle. Yeah,
Carlton Gibson 43:18
there was an weird but you talked about fundamentals, about, like, you know, someone learning with an LLM instead of, instead of doing, doing the hard time on the ATO. There's a similar point that gets made about web frameworks. The people begin, they begin by learning the web framework, and they never really learn about HTML and GSS and JavaScript, and so they come to a sort of more vanilla solution, like, Is that even possible? And they don't know. You know, there's lots that they just don't know. But yeah, if you're a youngster starting out and you need a job, you do the boot camp, you learn the framework, you apply for the job, you get the job, and maybe you never have that time. So if I'm a youngster coming through now, I need to, I work with the LLM, I get the code written. It may not be perfect, but that's the, you know, the dull hand of economic determinism doesn't give me time to sit down. No, I'm going to spend 10 years buying Yeah.
Sheena O'Connell 44:16
How do we mastering this? How do we Yeah, it's hard. How do we juggle that? How do we deal with that? It's tough, because you do need results. I think, I think you can do a lot of good in not that much time. Like, if you just like, focus on learning the fundamentals of a language. Like, it doesn't really take that long to learn what a variable is, what a return statement is, what a loop is. And people are skipping over that level of fundamentals, which is a problem that's like a big, big problem. But then when it comes to frameworks, it's it's tough in a lot of ways. So So I think certain frameworks are good teachers. So Django, for example, I think it's. Good teacher. I learned Python by learning Django, and I learned a lot about web development by learning Django and learning different frameworks. And like, even building stuff from like the ground up in different ways, has been made a lot easier because of because of what I've learned in Django. So that's cool. So a framework can be like, also a mental framework that you can hang new knowledge onto. And that's that's very helpful. So frameworks that are, like, really explicit about how they work is good. Some frameworks are less explicit. Some frameworks you you need to put your code in the in the right places, and then the magic happens. And while you have a thing, but you're not really sure how it happened. You just, you're just following the rules of this framework.
Will Vincent 45:45
Yeah, it's the magic and batteries. Pendulum is how I think about it. Yeah,
Sheena O'Connell 45:49
yeah. So I think explicit is better than implicit. Is that Zen? But then I think there's also, like, if somebody learns a framework and gets into their first job and is able to do certain things and not others because they've they're missing those foundations. Like if you if you don't have your foundational skills, you can only code to a certain level. There's a certain level of problems that you can work on, and some that are just like outside of your reach until you learn certain things. And those certain things aren't always obvious to the person who needs the skills like they are unknown unknowns. And for the organizations that hire the juniors as well, they're not necessarily set up to seek out those unknown unknowns and plug those knowledge gaps. And so sometimes a person will be writing code that makes them look like, I don't know, irresponsible or lazy in different ways, but it's like, oh, you actually just don't understand this one concept. That's why your codes like so repetitive, because you're not really that sure about how functions work. And so it's easy to almost like, see a person's like, nasty code, and that's like, a symptom of a problem. And you make you, like, fall into the trap of, like, attributing that symptom to to like, a personality trait sometimes, instead of like, Oh, they're just missing some skills, a moral failing, yeah, yeah, it's like, why are you writing such repetitive code? Just put it in a function, bruh, and then, and then they can't
Will Vincent 47:21
but I think that that's a, that's a good example where you can do this in some text editors, but to, like, to take code you've written and then as, just as an exercise, to throw it to an LLM and say, make this better. Because it will. It might well make it better, right? It might not. But, like, especially as you're learning, I think there is that, like, it's, like, what is that balance between your own stuff and the LLM? And I think the LM is great once you've given it a good college try, but that's what I use it for, you know? But, and then, yeah, but it's super helpful for that, because that's, that's where it's really strong. Like, testing is super strong. I think refactoring, it actually can be strong. It can also just be wildly hallucinating. But, you know, if that'd be interesting, it's almost, you almost want that could be a cool service, like every git commit, run it through just a refactor, LLM, and then, because it's actually like, you know, because I use, you know, I don't know that you like, I use pre commit on my my real projects, which is awesome, and a lot of times I'm just sort of like, yeah, just fix it and move on. You know. I'm not like, truly, like, you know, because, like, I added a space a lot of its HTML or white space stuff. But that would be an interesting idea for some sort of like, gut check with your drunk programming friend, because, yeah, if you Yeah, if you don't, I don't know, yeah, I just think about that. But that's, that's one I think an LM would would be really good for, is to spot you could do this function differently.
Sheena O'Connell 48:55
I think that can be cool. I haven't actually tried that, but that is interesting. I think people often use it for, like, explain this quote to me, which I think is useful, because if it can go line by line and make it clear, then that is very, very handy. And then what else do they do? Explain this error message to me. That's another really good one, error messages.
Will Vincent 49:19
And I think people don't realize, sorry, Carlton, I know. I say, like, who got?
Carlton Gibson 49:23
Well, it's good. Just put another example there. But is that why go on, you got? Well, sorry, I'll just continue
Will Vincent 49:28
on this point. Then I was just gonna say, you know, if you see that the LLM is wrong on something, if you say, are you know, are you sure? Is that you know incorrect? Those like, Oh, I'm sorry. And then a lot of times that second pass, it will get it a lot more, right? So, the thing is, it doesn't know, I mean, so I again, I, I see this all the time. So, like, as I'm trying to, I still very novice, but like, using it, you know, it's like, give me lots of ideas, and I'll split something up, like, Oh, that's not quite right. It's, it can, if you dial it in. And then the thing is, it also, we're. Members, it has a memory of your interactions. So for example, chat, G, P, T, like I used it for this for building, or I used to help building out learn django.com so now if I ask an unrelated Django question, it automatically gives responses kind of related to that project just because I've asked previous questions about it. So again, that's sometimes that's quite helpful, and then sometimes that's wildly unhelpful. I probably just need to say, like, yeah, don't, don't, just ignore it again. So yeah, a brave new world. But I feel like eventually that will be these things will be sorted out, like we're all driving a manual car, and soon it'll be a little more automatic. I think
Carlton Gibson 50:38
Carlton just gonna throw in the example there. There's, if you give it some test cases and say, write me some.or drive some dot. You know, lots of projects don't have great docs. And you can say, give me some usage docs for this, and it will come up with stuff that's readable and accessible. And you think, Okay, well, that was better than nothing. Yeah, that was better than the no docs that are currently there. So
Will Vincent 50:58
there, yeah, or, or switching, or switching, you know, switching from Django test to pi test. So Justin, Justin Duke, who's sponsoring this episode with button down, he has a blog post we'll link to. He used cursor for this, and just said, which is, which is an A AI power. It's like VS code with marketing and llms A little more. I'm sorry that's probably a disservice to it, but it's, it's very hot right now, but he just used it to port over the tests, right? And that's, that's a great use case of a testing is sort of but especially if it's a known thing, and to manually switch it over from pi to pi test or vice versa would really take a while. That'd be hard even for a knowledgeable person to do I think that's cool. Like
Sheena O'Connell 51:42
using it as a translation service. Like, if you know one language and you want to know another language, you can say, like, do this in rust and one then you're gonna be, like,
Will Vincent 51:54
do the tests pass or not? Right? That's the key thing, is that, and it doesn't hurt you to have tests that do or don't work. I think that's the key thing too, unlike fiddling with your, you know, authentication or something.
Carlton Gibson 52:07
So back to education, slightly to llms are obviously massive and hot and the new thing, and every all the money's going into them, and are they, they're pushing their way into ed tech. I take it quite rapidly. Is that the state of the art there is that? Is that, is that the exciting thing happening? What's your view on where that's
Sheena O'Connell 52:24
happening? But a lot of, like, there's a lot of hype, and a lot of teachers who aren't adopting these tools for lots of different reasons. And I think, like, there are issues. So the one was like, that, the thing I mentioned earlier about students having unknown unknowns. Like, sometimes they're really confident in their unknown unknowns, or, like, in how they think the world is. Like that guy mentioned earlier with the React, it's like, like, he wouldn't think to ask an LLM these questions. And sometimes it takes a human where he's like, I want to show you human, this thing that I'm that, that I like, like, it's they're unlikely to have that conversation with with a machine. They'll ask the questions that are focused on their known unknowns, or the rabbit holes that they want to go down, which aren't always like, like a human is a better guide in these cases. And I think the other thing that's that llms are supposedly good for is like, okay, the teacher can, like, input some stuff, and then it can solve the teacher's problems for this student or for this class. But it doesn't necessarily go that first mile where it's like, okay, what stuff does the teacher fill in? Like, everything they need to give like, so much context before they get an onset out a lot of the time. And it like, unless you've got, like, a new class of students, and you're doing something from scratch where the prompting is, like, pretty straightforward, if you're doing something for like, I've got this problem with this existing student, and here are their marks, and here is what they've done so far. And these are like this, like, I've spoken to their mom, and like, entering all of that is really hard. So like, that first mile is is tough, yeah. But there are, like, a lot of ways that it can be useful. I mean, there is stuff around content generation, creating, creating coursework and whatnot, and that's like, You got to be careful. You got to be very careful, yeah, especially if you're talking about something that's either like, new and novel. So if you're writing a course for, like, some, some kind of new software thing, then it's going to just make stuff up, because it doesn't know for something that's like, you know, robust and well used and whatnot, it'll make stuff up less. But if something's confusing, like Git, for example, then it'll make up weird stuff. So, like, I use llms when I'm making my workshops and stuff, because I sometimes I'm just like, how do I explain this weird thing? Like, give me a metaphor to explain this? Give me a story to explain this, explain why it's important, and then I can take that, and I mean, and like, adapt it quite a lot. And when I was making the get course, I asked it a bunch of questions like, whoa, that's actually, like, really misleading. What you're saying they get so, yeah, there's there's challenges there. I think other things like marking projects assessments, I think that's also like assessing a person's skills. Like, that's not a solved problem, even if you're having, like, humans do it. And it's very easy to, yeah, it's very easy to just, like, either focus on the wrong things or give people bad advice. So yeah, like, using an LLM to review student code sometimes gives them, like, really misleading advice.
Will Vincent 55:50
Well, which they probably wrote, wrote with an LLM, right? So that's possible,
Sheena O'Connell 55:54
yeah. But even if they didn't, it's like, just to get it, like, strict enough, but not too strict is really hard. So you need to, like, make sure that you're teaching them the lessons, but also not giving them like random, just like random nonsense to do. So, for example, I was trying to get, I was trying to get one of the like GPT models to review code at one point. And I was trying to be, like, just be a little stricter. Not that loosey goosey. And then eventually was at a point was like, every single unit test needs a full doc string. I'm like, that's like, weird advice to give to somebody who's learning how to code, because they often do very strange things with Doc strings and comments. So that's tricky. I do think that there's a lot of good stuff around just like, self assessment. So if you have low stakes assessments for for students, where they can sort of get a view of their own skills and where they're at, then that's super, super powerful. If the student is, like, plugged into it, and not just trying to, like, tick the boxes and move forward, like a lot of people have been trained to tick boxes. But if somebody's, like, genuinely interested in the feedback that they're getting, that they're like, they've been asked this question, they don't know the answer. Here's the answer, then that yeah, that can be very, very powerful. I don't think I've seen a lot of that, but it is, it is a good thing.
Carlton Gibson 57:17
I get keep getting the impression that, like you, it's clear to me that you believe that the human element in teaching is all important. And what's interesting, though, is the difficulty of making a single human go very far. Humans aren't very spreadable, right? We're quite Yeah, problem contained. So it doesn't sound as if you think there's a holy grail for that available in to you know, change it with the technological change will suddenly make education that much more accessible.
Sheena O'Connell 57:47
I think it'll I think it's like an 8020 thing. I think that you can do a lot with good tools and good content. But I do think, like, just from my experience with dealing with students, I've come across a few people. I'm like, I have no idea how I would have, like, detected this without, I don't know, making the students maybe jump through a lot of hoops, or having some, like, weird way to interrogate, interrogate them, because sometimes it's just a matter of, like, spending time with the student while they're doing a thing, and then you notice that they did something weird, or they said something weird, and you just like, let's Just dig in your brain a little bit and see what that was about. And that's not like, it's not easy, it's not something you can automate. But as far as I've seen anyway, like, I'm sure things will get better, but I yeah, I don't know how to automate that, but what I have noticed, and so, like, my kind of way of teaching people is, I teach adults. I don't teach kids because kids are like, they come with all sorts of different challenges, which I'm not that experienced in. I like them. That's the way I teach is more about just empowering the individual to almost teach themselves as much as possible. So that means, like, the very good content, very like clear content, very like steps that have been thought out very carefully, like the the content needs to be built in a way that, like, really takes, takes like learning mechanisms into account. So it's like, okay, spaced repetition and recall. And how can we get them to build mental frameworks and blah, blah, blah. So you you make, like, damn fine content, set them up for success as much as you can, and then when somebody struggles, you help them. And a lot of people will, like, a lot of people won't struggle, and that's great. And it's like, freaking go. You that. That's fantastic. You didn't need the human. And maybe, like llms can make that a bit better. So like, fewer people will need the human, but I think there'll still be, like, some folks who either get left behind or derailed because of weirdness. Yeah, and my
Carlton Gibson 59:56
my experience of teaching is that if you miss that building block. Then that's when you get you it's really important that someone's there to rescue them at that time, because otherwise they lose, they lost forever, and it was that one block.
Sheena O'Connell 1:00:10
And there's also a lot in teaching around, like, like a person's emotional journey to some extent. So like, if you're teaching somebody something hard if a person is learning software, like, it can be really, really frustrating in the beginning, because they'll, like, they'll forget to indent something, and then everything's wrong, or they or they're getting an error message because they forgot the colon, and they don't know about where the colon should be. Or, you know, when you make those, like, single character mistakes and then you, like, bump your head on it for hours. And people, like, often, they'll remember the emotional experience instead of, like, the end of things. So if they bump their head on a concept for like, hours and hours and hours, and then they won, and then they start bumping their head on the next concept for hours, and then, and then they win, they'll remember, like, this sucked. It was hard, you know, but sometimes it takes a teacher to be like, hey, you know that thing that you were struggling with last week, you're kind of nailing it now, because people don't always notice that in themselves, like the cheerleading aspect is actually pretty big.
Carlton Gibson 1:01:19
Yeah, my Tai Chi teacher is always like, no, no, don't look in front. Don't look at what you don't know or can't look how far you've come. It's, yeah, yeah,
Sheena O'Connell 1:01:30
yeah. That's a big deal. So
Will Vincent 1:01:32
this is going back 10 minutes. I wanted to add something to what you were saying about like, the example of a teacher not using an LLM. And I think one of the interesting things about LMS now is pre loading context. So, like, you know, I'm sure the three of us in a weekend, we could build crud plus auth that loaded in the records, you know, that just attended sheets so you see student name, t you know, parents like, you can load in this information. That makes it so that when you do ask prompts, it is kind of custom to you. So I do think there's, I think, I suspect that type of thing is where most of the efficiency gains are going to be unlocked, where it's not anything that creative. It's just like an existing thing sandbox it and just saves time, and it lets someone, you know, a teacher with 200 students, or, you know, whatever ungodly level, okay, it's never going to replace one on one, but they can do something in a way that they couldn't before. And a lot of stuff in the same way, code, some code, you know, these LMS can design code, and then we review it. I mean, if you look at so many businesses now, it's machines, it's humans signing off on something, right? I mean, it helps in medical for various reasons, with licenses and stuff. But, you know, radiologists, like many of them, are using stuff that, just, like, speeds it up, right? And so that, to me, cardiologists too, right? Like, I mean, you know, it's like, okay, patient has, boom, boom, boom, boom, boom, if it helps them be faster, or even think of new things, like they're using it at some of the hospitals here, just like prime primary care, you know, because turns out llms, I think, in the study I saw, are actually better than humans, because we have biases. Whereas if you just like presented patient information and symptoms, it can do a really good job, whereas we as humans, you know, are going off other factors. So it's interesting how I think it's, I think it's a great like enhancement, like a great cane or crutch. And I just, I think that's how it's probably going to be used, to not fully replace, but to, you know, bicycle for the mind or something.
Sheena O'Connell 1:03:42
It makes a lot of sense, but I think it's something like So earlier, I said, like, assessment in education isn't quite solved, and I think that that could lead to some some weirdness. I'll give you, like, an actual example of the thing that I saw. Students had to complete a bunch of projects. They had excellent X amount of projects, and they needed to get them done. And so this could be visualized as like a burn down chart, so you can see their progress over time. And that's great. And they're all like interacting with each other in different ways. Some of them are helping each other. Some of them are supporting each other in different ways. Great. And then there was this parallel stream of education stuff where people had to write these little tests based on basic coding Carters. So, like, super easy coding Carters from like, similar to hacker rank and delete code and all of that. And a lot of people were like missioning ahead of their projects, but they couldn't solve the most basic Carter. So it's like, you clearly don't know what a for loop means. You clearly don't know what a like how this return statement thing works. People get confused about that all the time, like all the time. And so we had these two men. Metrics of their performance. And depending on which one you prioritize, depends on like that. So like, if, if the project progress is the most important thing, then you will push people to maybe help each other more on their projects. Or you'll find ways to, like, push that a bit forward. And if the characters are the most important thing, then you'll say, like, cool. Let's look at your fundamentals. Do you understand this loop thing? So the projects were being prioritized and not the not the fundamentals. And I had to chat with one of the students, and I was like, I was like, okay, cool. Like, I've dug around in your brain, and it looks like these are the things that you're struggling with. And here's like, here's how you can practice it. And do you understand? Yes, yes. You understand how to go and practice it. Yes, will you No, it's like, why not? Like, I don't have time. It's like, why? Because I'm super too busy on my on my schoolwork. I was like, oh, so there's a lot around just, like, the possibility of optimizing for the wrong metric and not knowing, like, the trade offs between things, and it's very easy to get wrong, like I've seen some very smart people like do do some very strange things around optimizing for metrics.
Carlton Gibson 1:06:15
Yeah, I can't remember the name of the law now, but that, you know, as soon as it becomes a target, it gets gamed, right? It ceases to function as a measure, yeah,
Sheena O'Connell 1:06:25
yeah, yeah. It can be a big problem. Standardized tests, such a problem.
Carlton Gibson 1:06:33
So we have to mention your DjangoCon talk, which was amazing on, you know, education and the theory around it, and I don't know if we've got particular question, make sure we mention it and perhaps ask you about it a little bit. Yeah,
Sheena O'Connell 1:06:51
thanks. I really proud of that talk. It's it took some doing to just like, figure out what to say, because there's so much to be said about education and putting it into into a talk. It's like you really need to pick your battles. One thing I
Carlton Gibson 1:07:06
love is you keep using this phrase, dig around in people's brains, which is a lovely metaphor.
Sheena O'Connell 1:07:13
I yeah, I find that very important. So for me, like one of the main things I try to get teachers to to understand is, like, you need to understand the student so often, like, If a student doesn't understand a thing, then the teacher will try and explain it, and then they'll be like, Oh, you still don't understand I'll explain it a different way. Oh, you still don't get it. I'll explain it a different way. I've tried all my ways of explaining it. I'm like, That's me tapping out. But sometimes, if you just, like, like, almost try to investigate how the person is understanding it, and you say, like, cool, I've got a theory that you might be understanding it like this. My theory could be right or could be wrong. Let me try and think of some questions that you can answer, that you could get right or wrong, and that'll, that'll inform me so, so to be like a little bit of a scientist about, yeah, so you want to be a bit of a scientist and investigate the mental frameworks that people are building and how they interpret the things to work. And that makes teaching, like, way more stimulating, because explaining a for loop over and over again is like, not the most fun, but digging around in a person's brain that can be kind of fun, because they're all very different
Carlton Gibson 1:08:27
as well. It makes it like programming, right? Because we're trying to, if we're doing it right, in product design, we're trying to understand our users mental model and help them to build the correct mental model for our product via the UI or via the user experience that we offer that sounds very similar. I mean, clearly it's, you know, it's a sibling thing, but this, you know that there's a certain affinity between those two processes. We are
Will Vincent 1:08:51
coming a little bit up on time. I want to ask you, have we not asked you anything? Are there things you want to promote that you haven't so we're gonna have links to Prelude people. That's where people should go to find out about upcoming workshops and sign up for your newsletter. We took this girl right at
Carlton Gibson 1:09:05
the beginning. Ages ago, Sheena had a whole second thing that we just didn't talk about at all.
Sheena O'Connell 1:09:11
It's okay. This is such a good conversation.
Will Vincent 1:09:15
The Guild of educators, yes, we're neglecting perfect guild.
Sheena O'Connell 1:09:19
I always wanted a guild. So the idea there is, like, I've been looking at the software training ecosystem as a whole for a while, and there are lots of like things that are sub optimal in many different ways, and I'm trying to figure out how to nudge things in a good direction. And one of the things that I think is really powerful is just really valuing teachers and empowering teachers. So taking the humans in the system and just like making them, like reducing the dropout rate, because people just like drop out of teaching because they get frustrated for a lot of very good reasons. And so providing. Support structure, is a part of it, providing information and like, so that's, that's pretty cool. I've gotten a lot out of it just by talking to the members and saying, like, I've got this crazy idea, and then I can talk to them and they can poke holes in my idea, or, yes, and it, and that's been very, very helpful. So I want to, like, take the people who teach and just, like, up regulate them and myself. So that's that. And the idea with guild of educators and Prelude is, like, ideally, things should feed into each other in some way. So like, I'm trying new education things with Prelude, and I'm learning lessons, and I would like to share those lessons with other teachers. And I also know that teachers, like, at some point I'll be able to hire some people, and it would be good to have those relationships already in place, so I can like, like, hire people who know what's up, or hire people who need teaching experience and give them a chance to learn. So that's that, and it's there's a completely free community guild of educators.org, just like sharp and join the discord, and we'll start having events again soon. Yeah. So that's that. And then things to plug, actually. So my newsletter is on my personal blog. I'm still, like, I've got a lot of I've got a lot of tidying up to do on the like, I like marketing, identity, brand front, but yeah, if you go to my blog, then you can sign up for the newsletter and I talk about
Will Vincent 1:11:36
it. And what is the URL of your blog? It is
Sheena O'Connell 1:11:39
Sheena oc.com, or actually no, OC is one word.
Will Vincent 1:11:43
Yeah, we'll have a link to it too.
Sheena O'Connell 1:11:47
Yeah. So you'll hear about all of the things, all of the training things, all of the things I'm thinking about, and some random stuff which is fun. And with Prelude, I've got a couple of courses coming up. So I've got one on Git coming up very, very soon. It is happening on the 24th which is a Friday. This
Will Vincent 1:12:06
comes out on week 5/23, so that's pretty quick turnaround, but if there's spots, there's a day, well, I'm
Sheena O'Connell 1:12:16
doing another modern front end dev workshop twice mid February. And so folks could sign up for that if they're keen. It is super fun. And yes, I could give you a discount code. I can say Django chat rocks with underscores, and we'll give you a discount, which is great. Yeah, I suppose there is actually, like, one more thing to mention. I know this is getting logged out, but like, so one of my things that I'm trying to do with Prelude is generate extra goodness that I can share with different people. Because there are people who can afford training, and there are people who can't. And like, I am in South Africa, I am in Africa, there's a lot of people who could do with training. But just like, there's challenges here. So I aim to like, so I charge money for the workshops, and the goal is to make them affordable for folks in like, the US and Europe and whatnot, and then use excess capacity and whatever excess funds I have I can use to train folks in and around Africa. So I'm, like, still figuring out how to best distribute that, like, I'm still experimenting around that front but, yeah, that is a fun thing that I'm working on.
Will Vincent 1:13:39
No, and that's cool. Well, you can't solve all the problems at once, right? You got to go iterate, iterate through them.
Sheena O'Connell 1:13:45
Yeah, yeah, iterating. It's there's a lot right now, but it's all very exciting.
Will Vincent 1:13:52
We'll get, we'll have to have you back on, and I don't know, six, 612, months, and you can tell us how everything's been a success, hopefully, yeah, so, and it's so good to catch up. I think we both saw you at the Django cons. You were doing kind of a whole little world tour of conferences, which you didn't get to ask you about. But yeah, really excited to see this is where you've ended up, and that it's really taken off. And I'm not surprised. I mean, to have a knowledgeable, passionate educator who knows Django and web stuff is you almost can't pay enough to that kind of person, and the fact that you're still clearly enjoying it and doing it,
Sheena O'Connell 1:14:31
yeah, it's a hell of a Venn diagram.
Will Vincent 1:14:34
Yeah. All right, so I'll wrap it up. So we are Django chat.com, links to everything in the show notes, and we'll see everyone next time bye bye bye bye.
This episode was brought to you by Buttondown The easiest way to start send and grow your email newsletter.