this post was submitted on 20 Jul 2024
115 points (96.7% liked)

Programming

17651 readers
443 users here now

Welcome to the main community in programming.dev! Feel free to post anything relating to programming here!

Cross posting is strongly encouraged in the instance. If you feel your post or another person's post makes sense in another community cross post into it.

Hope you enjoy the instance!

Rules

Rules

  • Follow the programming.dev instance rules
  • Keep content related to programming in some way
  • If you're posting long videos try to add in some form of tldr for those who don't want to watch videos

Wormhole

Follow the wormhole through a path of communities [email protected]



founded 2 years ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 21 points 5 months ago* (last edited 5 months ago) (4 children)

I, as a teacher, have had to learn several languages, but that's not the dumb reason bit. The dumb reason bit was WHY I had to teach Python, which once I learnt it (so I cold teach it) I could see right away was NOT a suitable language for teaching to Year 7 (who up to now have only used Scratch). I was teaching the U.K. curriculum, and I found out that teaching C# was also allowed - still not ideal, but better than Python for learners -but pretty much all schools were teaching Python. When I dug into it I found I was far from alone in not wanting to use Python... and I also found out the reason schools were teaching Python. It was because from an ADMINISTRATIVE point of view it was much easier for the schools to have us teaching Python. In other words, the office-workers who didn't have to teach it, only had to admin it, were forcing everyone to teach Python because they wanted the lower overhead that came with installing/maintaining that vs. C#. ARGH! All the teachers who wanted to teach C# were running into exactly the same road-block.

[–] [email protected] 38 points 5 months ago (3 children)

I'm really surprised to hear that teaching C# to 7th graders is easer than teaching them python. Python was invented to teach. It looks like pseudo code. I have almost zero experience in teaching so I trust your experience. But can you elaborate a little? What makes teaching C# easier?

[–] [email protected] 18 points 5 months ago (1 children)

Surely an unpopular opinion lol.

Python is a great first language.

[–] [email protected] 4 points 4 months ago (1 children)

...and riding a bike is easy. Now go watch some kids who have never ridden a bike before and see how that's working out for them.

[–] [email protected] 2 points 4 months ago

as an adult who never rode a bike I can see

[–] [email protected] 9 points 5 months ago (2 children)

I just replied to someone else with the same question. Less can go wrong (but in either case a non-OOP language, like Pascal, is a much better starting point. You should only ever teach students one concept at a time).

[–] [email protected] 5 points 5 months ago (1 children)

Pascal was my first language. Self-taught. It was pretty good.

[–] [email protected] 2 points 4 months ago

My first language was Basic, and Pascal is definitely better than that as a first language (it's what it was designed for).

[–] [email protected] 4 points 5 months ago (1 children)

As it is, when we had to teach them HTML, the resources we were given were using PHP at the same time, so I scrapped that and just taught them HTML myself. We never teach more than one concept at a time, so I don't know how these other things found their way into the curriculum/resources.

[–] [email protected] 6 points 5 months ago (2 children)

It looks like pseudo code

P.S. as a teacher, I can tell you I have seen students who even struggle to write pseudo code. It's like trying to teach them Greek (not all students, but some, and we need to cater to the lowest common denominator).

[–] apolo399 5 points 5 months ago* (last edited 4 months ago) (1 children)

I hate having to cater to the lowest common denominator, I had to struggle with un-engaging classes all throughout elementary and middle school. I've seriously thought about becoming a teacher so I'd like to ask, in your experience, what happens to the children that are able to process more advanced information? Can something be done to keep them engaged and nurture their development too?

Edited an unfortunate typo

[–] [email protected] 2 points 4 months ago (1 children)

Oh definitely! Different students have different learning styles - some learn by memorising rules (ROTE), some learn by understanding the rules (Constructivist), some are visual learners, some are better at learning in group activities, etc. - and we have to cater to them ALL, to keep them all engaged (here's WHY we have this rule, here's a video about it, here's a group activity about it, here's a worksheet to practise it). But I was referring to the TOOLS that we use with class. We can't use a tool that the advanced students have no trouble with but the less adept students struggle with - we have to use a tool that the whole class can use, and that's what I meant about catering to the lowest common denominator.

Also some (not all) schools have special classes for gifted and talented (G&T) students. And in fact one class I've had in my time is a class which was comprised of half the students had various learning difficulties (such as being dyslexic), though they weren't told that (these days it's all about trying to keep them in the mainstream as much as possible. So in this class the dyslexic student had a regular student sitting next to him for immediate help with reading anything, which left me free to only need to help him with actual educational issues).

[–] apolo399 3 points 4 months ago (1 children)
[–] [email protected] 1 points 4 months ago

No problem. Feel free to ask me questions.

[–] [email protected] 3 points 5 months ago

Oh! I just remembered this video. If you wanna know how students can struggle with pseudo code, watch the video. I use this video when I teach algorithms (students are even worse at that than pseudo code).

[–] [email protected] 6 points 4 months ago

it looks like pseudo code

Does it though? I imagine most pseudocode looks like the language the writer is most familiar with. My pseudocode definitely doesn't look like python.

[–] [email protected] 15 points 5 months ago (1 children)

I've always seriously questioned why python has become the defacto beginner language. Sure, a simple print hello world is short, but I feel like static languages are easier to see what's going on.

[–] [email protected] 5 points 4 months ago

Well, I'm only speaking here for my experience with teaching the U.K. curriculum, but probably the same thing applies elsewhere. I know this much - as a teacher, it's very frustrating!

[–] [email protected] 10 points 5 months ago (1 children)

I'm curious why you think Python is unsuitable. Both of my kids picked up Python pretty easily.

[–] [email protected] 17 points 5 months ago (5 children)
  • object-oriented (this is their FIRST proper programming language - they don't even know how to write loops yet and you want us to teach them OOP at the same time?! And as it turns out, I had one student who literally could NOT work out how to use a loop - kept writing 20 variables for 20 iterations. i.e. her variables never varied!)
  • variables are weakly-typed (use it for anything, whether it's what you first used it for or not, Python doesn't care)
  • indentation has to be exact (i.e. no brackets, just exact indentation). I had one student whose program wasn't working, and it even took ME a while to find what was wrong with it (a missing space).

I think there was more, but that's what I remember off the top of my head. If it was up to me then I would've used Pascal - that's what it's designed for! But at least C# has strongly-typed variables, and doesn't care about your indentation (and unfortunately there was no non-OOP language choice available - I'm not sure how this got in the curriculum when every teacher knows you only teach one concept at a time). As I said, many other teachers felt the same way, but couldn't get it past their school admin's.

[–] [email protected] 4 points 5 months ago

Notably, when I did my C.S. degree, they knew to only teach one concept at a time. We learnt Pascal in first year, then did OOP in second year.

[–] [email protected] 3 points 5 months ago* (last edited 5 months ago) (2 children)

object oriented

Python does have OOP but you are not at all forced to use it. You can write code in a functional or even procedural style.

typing

I do hate that python doesent have proper support for typing but I think weakly typed variables will actually help beginners as it is less to think about to start off with.

indentation

I think there are pros and cons here. In other languages it is considered good style to use indentation anyway.

I'm sure it is difficult to teach a large class like that though. It was hard enough for me to learn with a much more favourable teacher to student ratio than you probably have. Sorry but honestly I do sympathise with admin as well.

[–] [email protected] 6 points 4 months ago

Python does have OOP but you are not at all forced to use it.

Not as an individual, but I'm talking about a situation precisely where the individual choices of teachers are ignored, in some cases by school admins, in some cases by faculty choices. Fortunately I also ran a computing club, in which I was autonomous with how I ran it, and I taught my computing club students C#/MAUI... but even then still saw some of the issues you run into with teaching students. e.g. I told them to install Visual Studio ready for next week, showed them where it was, what workloads to install, and then the next week one of the students had installed Blend for Visual Studio, not Visual Studio. "Look, it has Visual Studio in the name!". (sigh)

I think weakly typed variables will actually help beginners as it is less to think about to start off with

No, that's exactly the problem to start with. Another rule of teaching (see below for the full list I'm quoting these from) is "never let the first impression be a wrong one". If you let students think they can use variables for anything, then you run into problems when they can't. This is why teaching them with strong types first is better - they learn you need to be careful with how to use them, THEN maybe you can let them have some more freedom like Python allows.

In other languages it is considered good style to use indentation anyway

Yes, but in those languages it's optional. In Python it's mandatory, and if someone's code isn't working it's far easier to spot a missing bracket than a missing space.

[–] [email protected] 5 points 4 months ago (2 children)

It's odd to me that you're disagreeing with their actual experience teaching.

[–] [email protected] 3 points 4 months ago* (last edited 4 months ago)

Thanks. It's a very 21st Century phenomenon that I've unfortunately run into many times

[–] [email protected] -1 points 4 months ago (2 children)

Lots of us have the experience of being the kid in that situation though. I learnt python in secondary school.

[–] [email protected] 4 points 4 months ago

They've been through the other side of this experience multiple times though.

[–] [email protected] 3 points 4 months ago* (last edited 4 months ago) (1 children)

have the experience of being the kid in that situation

Which kid? The gifted one, the one who didn't understand loops and used 20 variables for 20 iterations, the one who didn't understand how to write pseudo code, the one who was dyslexic,.....?

I learnt python in secondary school

Which Year? I didn't say it wasn't appropriate for high school, I said it wasn't appropriate for Year 7 as a first programming language.

[–] [email protected] 2 points 4 months ago

Lots of us

Also, who do you mean by "us"? Programmers? Not all the kids in class want to be programmers, and this isn't a programming class - it's Computer Science. We cover topics like hardware, the Internet, Cybersecurity, the history of computers, data analytics, etc. Not only do not all of them want to be programmers, not even all of them want to be in I.T. - they're just, you know, interested in computers (or in some cases they're in the course because their parents think they should be in it - I've had a couple of those students). We only spend 6 weeks on programming (we spend 6 weeks on each topic), or sometimes we might do it twice and spend 12 weeks on it, and that's it for the year! You can't teach Year 7 kids algorithms, pseudo code, basic programming concepts (variables, branches, and loops) and OOP as well in one year. Especially when not even all of them are interested in programming. It's just one topic we cover. OOP is something that shouldn't be covered until at least Year 8, preferably Year 9 (by which stage students have decided if they want to continue on this path or not, and the ones we still have left we start getting more hard-core... which is where the "us" I presume you're referring to come in).

[–] [email protected] 3 points 5 months ago (1 children)

You can use types in Python and your tools will generate warnings

def something(a: int) -> int: return "potato"

will turn yellow in an IDE more advanced that notepad.

Most editors will also show a red line where the indentation is wrong.

[–] [email protected] 4 points 4 months ago (1 children)

Most editors

Same thing still applies - you need to get it past the school admin gatekeeper.

[–] [email protected] 3 points 4 months ago (1 children)

If you're writing any language in like notepad, you're going to have a bad time. I accept your point that school administration may be making questionable choices about what software is installed, but that's not a problem unique to python.

[–] [email protected] 3 points 4 months ago

that’s not a problem unique to python

No, but it's a bigger problem for C# than is is for Python (though this is changing now), so all the U.K.-based schools were teaching Python, rather than the more-appropriate C#. That was my original point - that's the dumb reason I had to learn Python, school admin's wanted the lower overhead of the worse language.

[–] [email protected] 2 points 5 months ago (1 children)

Why do you even have to mention OOP? C# is object oriented too. Would you start explaining OOP too when teaching C#?

Python is comparatively easier as it's nearly literally pseudo-code. There's no need to even write a main function or functions at all. It uses less characters too e.g no need for semi-colon, brackets in for loops and if statements

As for indentation being exact, IMO that's on you. Beginners should be given a proper development environment to work in that helps them as much as possible. Modern editors and IDEs point out syntax errors and indentation errors are incredibly basic. If they are working in an environment that doesn't even point that out to them, they have been setup incorrectly.

Anti Commercial-AI license

[–] [email protected] 7 points 5 months ago (1 children)

Why do you even have to mention OOP?

Because I was saying why it's a bad choice to teach to Year 7. I already said if it was up to me I'd teach them Pascal.

C# is object oriented too

Yes, I know, but in this case it's the lesser of 2 evils, for the other reasons I gave.

Python is comparatively easier as it’s nearly literally pseudo-code

And as I just said to someone else, students even struggle with pseudo code.

e.g no need for semi-colon, brackets

And I already said that's one of the drawbacks - indenting has to be EXACT or your program doesn't work anymore.

As for indentation being exact, IMO that’s on you

It's not on me - it's in the language itself to begin with. I have no control over it.

Beginners should be given a proper development environment to work in that helps them as much as possible. Modern editors and IDEs point out syntax errors and indentation errors are incredibly basic

Now see if you can get the school admin's to install those ones. As I said, that's the root issue to begin with - the school admin's.

If they are working in an environment that doesn’t even point that out to them, they have been setup incorrectly

Now see if you can get the school admin's to fix it. Welcome to the struggle the teachers face in teaching what WE want to teach them.

[–] [email protected] 5 points 5 months ago (1 children)

It seems you did the best you could with what you had to work with. It's a shame the other users don't understand that you didn't get to choose the tools your students could use and instead went with what they, in their freedom to choose and install what they want, would have used to teach. I can imagine you only had notepad and Idle to use.

[–] [email protected] 2 points 4 months ago

Thanks. From memory we were using repl.it, or something very similar. This made it easy for me to look at their code when they had problems (and even then, as I said to someone else, it was quite a while before I realised one of them simply had the wrong indentation on one line - I kept looking at the code and thinking I couldn't see anything wrong with it, then eventually I realised there was a wrong indentation. If it took me that long to realise, then of course that's something students are going to struggle with).

[–] [email protected] 0 points 4 months ago (1 children)

I learnt to program in python (in year 12). It was pretty good:

  • less intimidating than the languages full of braces/brackets.
  • as it's also a scripting language, you can ignore OOP and just write code.
  • has lots of kid friendly drawing libraries (tortoise.py anyone?) so they can make things they can see on screen etc
[–] [email protected] 3 points 4 months ago (2 children)

I learnt to program in python (in year 12)

Yes, it's fine for Year 12 - you've already learnt all that stuff by then - it's NOT fine for Year 7 as a first proper programming language, when they haven't learnt ANY of that stuff yet.

[–] [email protected] 1 points 4 months ago (1 children)

P.S. the students aren't going to have any tests where it matters until Year 10, and the curriculum even says that at least 2 languages must be taught (in my case we chose HTML as the second language, because...), and so even though many teachers would like to teach their students C#, the schools simply aren't LETTING them do that. They don't want the admin overhead that comes with teaching C#, so it's Python and.... nope, it's just Python (and so then you have teachers opting for a second language like HTML, cos they can't get their school/faculty to buy-in on teaching C#, simply because they don't want the admin that comes with it. The fact that it's a better language to learn isn't even considered).

[–] [email protected] 1 points 4 months ago (1 children)

Is the fact that C# produced executables also a problem? With python you can 'protect' non lab computers at the school by just not installing the python runtime on them. Teach them c# and I guarantee they will be making executables to cause trouble.

Generally agree with you that teachers should be able to choose at least one of the languages to teach. basic web dev stuff is probably pretty useful to them though if it includes JavaScript?

[–] [email protected] 1 points 4 months ago (1 children)

Is the fact that C# produced executables also a problem?

Trust me, the conversation never even gets that far.

just not installing the python runtime on them

We weren't! We were using repl.it (or something very similar). I don't know what the story was at other schools, other than many other teachers also wanted C# but had to do Python (it was when I came across this that I finally accepted defeat in trying to get another language in instead of Python. I wanted to start with Pascal and then do C#. In the end I had to do HTML and Python. i.e. the status quo).

Generally agree with you that teachers should be able to choose at least one of the languages to teach.

We're supposed to be able to choose both languages, but school admins are taking away one of our choices.

if it includes JavaScript?

I wouldn't do that at the same time as HTML - maybe later, separately. As I've said, as teachers we only teach one concept at a time.

[–] [email protected] 1 points 4 months ago

P.S.

teach them c# and I guarantee they will be making executables to cause trouble

No, you're overestimating the students ability. I taught C# in coding club (they were mostly around Year 8), and it was a struggle just getting them to understand basic programming concepts (imagine having to explain MVVM to them - they're not good at understanding abstraction) - they wouldn't have had a clue how to turn it into a malicious exe.

[–] [email protected] 1 points 4 months ago* (last edited 4 months ago) (1 children)

I leant from scratch as my first programming language in year 12.

They tried to teach OOP in year 13, but I didn't really get it until university.

This was years ago at this point, I think they introduced the programming GCSE the year after I did my A-Levels.

A scripting language like python is the ideal language to start with because you can JUST learn the programming bit without worrying about OOP, project structures, compiling etc.

[–] [email protected] 3 points 4 months ago (1 children)

I think they introduced the programming GCSE the year after I did my A-Levels

I was teaching the IGCSE, to students all over the globe.

you can JUST learn the programming bit

But NONE of the resources which have been provided to schools do it that way - they ALL use OOP. If that's what your faculty has chosen to use, then that's what you have to use. It comes back to what I've been saying all along - the schools are dictating to the teachers what they are to teach, and it's NOT based on what's best for the students educationally, but what has the least admin overhead for them. That's the stupid reason that I had to learn Python - admin concerns!

[–] [email protected] 2 points 4 months ago (1 children)

Oh, ok, that's annoying then. One of those cases where it feels like the person putting the course together has never actually interacted with children?

[–] [email protected] 1 points 4 months ago (1 children)

Yes, that's exactly what I'm saying. The decision was made for us by school admins, NOT CS teachers. That's why it was the stupid reason I had to learn Python.

[–] [email protected] 1 points 4 months ago* (last edited 4 months ago)

Oh, I should clarify that. Teaching Python was decided for us by admins. The course material MAY have been designed by a teacher, but then also it may have been designed for Year 9 say. It's inappropriate to be teaching it to Year 7 as a first proper programming language, but that's what we had to do (otherwise then we would also have to make all our own resources to do it, and don't forget at this point that I didn't know how to program in Python myself yet! So yes, I had to use the already made resources, which had OOP in it).

[–] [email protected] 2 points 4 months ago* (last edited 4 months ago) (1 children)

Honestly, I taught myself JS in like 2009 as my first programming language. My high school taught Java, but I didn't get OOP. I understand functional programming though, so after JS I taught myself Elixir, then OCaml and Haskell. I really wish I was just taught Clojure or another lisp-like in school though. Python is... okay... I need expressions in my language, though, and Python is not that.

[–] [email protected] 2 points 4 months ago

My high school taught Java, but I didn’t get OOP

Yes, the correct sequence of events - one thing at a time, basic programming, then OOP. :-)

Python is not that.

It's not a lot of things, which makes it poor for a teaching language.