I was looking around for this type of code, before writing something myself. I'm sure it exists somewhere on the forums, but I didn't obviously look hard enough. I'm just posting to share this if anyone wants it. It could be stuffed into functions.php too.
[Code moderated as per the Forum Rules. Please use the pastebin]
Hope it's useful.