Beginner Projects
A list of projects for beginners.
Table of Contents
Getting Started
If you're completely new to programming, you may want to look into a tutorial. Before starting, you should already know the basics of programming such as variables, loops, dictionaries, and how to define functions, as well as how to run programs on your own machine.
Each project idea has a basic goal for you to achieve, as well as subgoals that require a bit more thought, but help make your program more interesting. The overall intent for this repository is to serve as a learning resource for everyone and to help transition learners from a beginning level to an intermediate level. In addition, learners are encouraged to contribute their solutions to this repository and thereby learn the basics of Git.
Almost all projects can be completed in any language, but some were specifically written to be completed with Python.
Remember, if you don't know how to do something, Google is your friend.
Gitter Community
Feel free to join us on our Gitter channel where we can code together, chat, and get help on just about anything.
Project List
Projects are somewhat ordered by increasing difficulty.
- 99 Bottles
- Magic 8 Ball
- Pythagorean Triples Checker
- Rock Paper Scissors Game
- Coin Estimator By Weight
- Mad Libs Story Maker
- Change Calculator
- Mean, Median, and Mode
- Higher Lower Guessing Game
- Multiplication Table
- Fibonacci Sequence
- Base Jumper
- Hangman Game
- Menu Calculator
- Dice Rolling Simulator
- Count and Fix Green Eggs and Ham
- What's My Number?
- Factors of a Number
- Countdown Clock
- Turn Based Pokemon Style Game
- A Variation of 21
- Compare Recent reddit Karma
- Watch for New TIL Facts
- Random Wikipedia Article
- What's the Weather?
- Sierpinski Triangle
- Two Numbers
- Chickens and Rabbits
- FLAMES Game
- Pomodoro Timer
- Scarne's Dice
- GoogleCase
Projects
99 Bottles
- Create a program that prints out every line to the song "99 bottles of beer on the wall."
- Do not use a list for all of the numbers, and do not manually type them all in. Use a built in function instead.
- Besides the phrase "take one down," you may not type in any numbers/names of numbers directly into your song lyrics.
- Remember, when you reach 1 bottle left, the word "bottles" becomes singular.
Magic 8 Ball
- Simulate a magic 8-ball.
- Allow the user to enter their question.
- Display an in progress message(i.e. "thinking").
- Create 20 responses, and show a random response.
- Allow the user to ask another question or quit.
- Bonus:
- Add a gui.
- It must have box for users to enter the question.
- It must have at least 4 buttons:
- ask
- clear (the text box)
- play again
- quit (this must close the window)
Pythagorean Triples Checker
- If you do not know how basic right triangles work, or what a Pythagorean Triple is read these articles on Wikipedia¹ ².
- Allows the user to input the sides of any triangle in any order.
- Return whether the triangle is a Pythagorean Triple or not.
- Loop the program so the user can use it more than once without having to restart the program.
Rock Paper Scissors Game
- Create a rock-paper-scissors game.
- Ask the player to pick rock, paper or scissors.
- Have the computer chose its move.
- Compare the choices and decide who wins.
- Print the results.
- Subgoals:
- Give the player the option to play again.
- Keep a record of the score (e.g. Player: 3 / Computer: 6).
Coin Estimator By Weight
When some people receive change after shopping, they put it into a container and let it add up over time. Once they fill up the container, they'll roll them up in coin wrappers which can then be traded in at a bank for what they are worth. While most banks will give away coin wrappers for free, it's convenient to have an idea of how many you will need. Instead of counting how many coins you have, it's easier to separate all of your coins, weigh them, and then estimate how many of each type you have and then how many wrappers you'll need. For example, if you weigh all of your dimes and see that you have 1276.9g of them, you can estimate that you have about 563 dimes (since each one is 2.268g) and you would be able to fill 11 dime wrappers.
Here is the weight of each coin and how many fit inside each type of wrapper.
- Allow the user to input the total weight of each type of coin they have (pennies, nickels, dimes, and quarters).
- Print out how many of each type of coin wrapper they would need, how many coins they have, and the estimated total value of all of their money.
- Subgoals:
- Round all numbers printed out to the nearest whole number.
- Allow the user to select whether they want to submit the weight in either grams or pounds.
Mad Libs Story Maker
Ever played Mad Libs? If you haven't, here are the basics:
"Mad Libs consist of a book that has a short story on each page with many key words replaced with blanks. Beneath each blank is specified a lexical or other category, such as "noun," "verb," "place," or "part of the body." One player asks the other players, in turn, to contribute some word for the specified type for each blank, but without revealing the context for that word. Finally, the completed story is read aloud. The result is usually comic, surreal and somewhat nonsensical."
- Create a Mad Libs style game, where the program asks the user for certain types of words, and then prints out a story with the words that the user inputted.
- The story doesn't have to be too long, but it should have some sort of story line.
- Tip: it's easiest to write out a quick story on a piece of paper or a word document, and then go back through and see which words the user should be able to change.
- Subgoals:
- If the user has to put in a name, change the first letter to a capital letter.
- Change the word "a" to "an" when the next word in the sentence begins with a vowel.
Change Calculator
- Imagine that your friend is a cashier, but has a hard time counting back change to customers.
- Create a program that allows him to input a certain amount of change, and then print how how many quarters, dimes, nickels, and pennies are needed to make up the amount needed. Example: if he inputs 1.47, the program will say that he needs 5 quarters, 2 dimes, 0 nickels, and 2 pennies.
- Subgoals:
- So your friend doesn't have to calculate how much change is needed, allow him to type in the amount of money given to him and the price of the item. The program should then tell him the amount of each coin he needs like usual.
- To make the program even easier to use, loop the program back to the top so your friend can continue to use the program without having to close and open it every time he needs to count change.
Mean, Median, and Mode
In a set of numbers, the mean is the average, the mode is the number that occurs the most, and if you rearrange all the numbers numerically, the median is the number in the middle.
- Create three functions that allow the user to find the mean, median, and mode of a list of numbers. If you have access or know of functions that already complete these tasks, do not use them.
- Subgoals
- In the mean function, give the user a way to select how many decimal places they want the answer to be rounded to.
- If there is an even number of numbers in the list, return both numbers that could be considered the median.
- If there are multiple modes, return all of them.
Higher Lower Guessing Game
- Create a simple game where the computer randomly selects a number between 1 and 100 and the user has to guess what the number is.
- After every guess, the computer should tell the user if the guess is higher or lower than the answer.
- When the user guesses the correct number, print out a congratulatory message.
- Subgoals:
- Add an introductory message that explains to the user how to play your game.
- In addition to the congratulatory message at the end of the game, also print out how many guesses were taken before the user arrived at the correct answer.
- At the end of the game, allow the user to decide if they want to play again (without having to restart the program).
Multiplication Table
- Create a program that prints out a multiplication table for the numbers 1 through 9.
- It should include the numbers 1 through 9 on the top and left axises, and it should be relatively easy to find the product of two numbers. Do not simply write out every line manually (ie print('7 14 21 28 35 49 56 63') ).
- Subgoals:
- As your products get larger, your columns will start to get crooked from the number of characters on each line. Clean up your table by evenly spacing columns so it is very easy to find the product of two numbers.
- Allow the user to choose a number to change the size of the table (so if they type in 12, the table printed out should be a 12x12 multiplication table).
Fibonacci Sequence
If you do not know about the Fibonacci Sequence, read about it here.
- Define a function that allows the user to find the value of the nth term in the sequence.
- To make sure you've written your function correctly, test the first 10 numbers of the sequence.
- You can assume either that the first two terms are 0 and 1 or that they are both 1.
- There are two methods you can employ to solve the problem. One way is to solve it using a loop and the other way is to use recursion.
- Try implementing a solution using both methods.
Base Jumper
- Create a program that converts an integer to the specified base.
- The program should ask for 3 inputs. The number to convert. The base the number is in. And the base to convert the number to.
- The program should accept a base that is in the range of 2 to 16 inclusive.
- Display the result to the user and ask if they want to exit or convert another number.
- Subgoals:
- Do not display leading zero's in the result.
- Validate that the number entered is valid for the specified base
Hangman Game
- Create a program that selects a random word and then allows the user to guess it in a game of hangman.
- Like the real game, there should be blank spots for each letter in the word, and a part of the body should be added each time the user guesses a letter than is not in the answer.
- You may choose how many wrong turns the user can make until the game ends.
- Subgoals:
- If the user loses, print out the word at the end of the game.
- Create a "give up" option.
Menu Calculator
Imagine you have started up a small restaurant and are trying to make it easier to take and calculate orders. Since your restaurant only sells 9 different items, you assign each one to a number, as shown below.
-
- Chicken Strips - $3.50
-
- French Fries - $2.50
-
- Hamburger - $4.00
-
- Hotdog - $3.50
-
- Large Drink - $1.75
-
- Medium Drink - $1.50
-
- Milk Shake - $2.25
-
- Salad - $3.75
-
- Small Drink - $1.25
To quickly take orders, your program should allow the user to type in a string of numbers and then it should calculate the cost of the order. For example, if one large drink, two small drinks, two hamburgers, one hotdog, and a salad are ordered, the user should type in 5993348, and the program should say that it costs $19.50. Also, make sure that the program loops so the user can take multiple orders without having to restart the program each time.
- Subgoals:
- If you decide to, print out the items and prices every time before the user types in an order.
- Once the user has entered an order, print out how many of each item have been ordered, as well as the total price.
- If an item was not ordered at all, then it should not show up.
Dice Rolling Simulator
By using the random module, Python can do things like pseudo-random number generation.
- Allow the user to input the amount of sides on a dice and how many times it should be rolled.
- Your program should simulate dice rolls and keep track of how many times each number comes up (this does not have to be displayed).
- Finally, print out how many times each number came up.
- Subgoals:
- Adjust your program so that if the user does not type in a number when they need to, the program will keep prompting them to type in a real number until they do so.
- Put the program into a loop so that the user can continue to simulate dice rolls without having to restart the entire program.
- In addition to printing out how many times each side appeared, also print out the percentage it appeared. If you can, round the percentage to 4 digits total OR two decimal places.
- Bonus:
- You are about to play a board game, but you realize you don't have any dice. Fortunately you have this program.
-
- Create a program that opens a new window and draws 2 six-sided dice
-
- Allow the user to quit, or roll again
- Allow the user to select the number of dice to be drawn on screen(1-4) 2. Add up the total of the dice and display it
Count and Fix Green Eggs and Ham
Some of you may remember the Dr. Sues story "Green Eggs and Ham". For those of you that don't remember it or have never heard of it, here is the story. However, there is a problem with the story I gave you - every time the word I is used, it is lowercase. Because of this problem, your job is to do the following:
- Copy the story I gave you into a regular text file.
- Create a program that reads through the story and makes the letter i uppercase any time it should be. (Make sure to change it when it's used in sam-I-am's name too.)
- Have your program make a new file, and have it write out the story correctly.
- Print out how many errors were corrected.
- When you're finished, you should have corrected this many errors.
What’s My Number?
Between 1 and 1000, there is only 1 number that meets the following criteria:
- The number has two or more digits.
- The number is prime.
- The number does NOT contain a 1 or 7 in it.
- The sum of all of the digits is less than or equal to 10.
- The first two digits add up to be odd.
- The second to last digit is even and greater than 1.
- The last digit is equal to how many digits are in the number.
To find out if you have the correct number, click here.
Factors of a Number
- Define a function that creates a list of all the numbers that are factors of the user's number.
- For example, if the function is called factor,
factor(36)
should return[1, 2, 3, 4, 6, 9, 12, 18, 36]
. - The numbers in your list should be sorted from least to greatest, and 1 and the original number should be included.
- Remember to consider negative numbers as well as 0.
- Bonus:
- Have the program print the factors of the users number in a comma separated string, without a comma after the last number, and without the brackets of a Python list.
- If the user's number is prime, note it.
Countdown Clock
- Create a program that allows the user to choose a time and date, and then prints out a message at given intervals (such as every second) that tells the user how much longer there is until the selected time.
- Subgoals:
- If the selected time has already passed, have the program tell the user to start over.
- If your program asks for the year, month, day, hour, etc. separately, allow the user to be able to type in either the month name or its number.
- TIP: Making use of built in modules such as time and datetime can change this project from a nightmare into a much simpler task.
Turn Based Pokemon Style Game
- Write a simple game that allows the user and the computer to take turns selecting moves to use against each other.
- Both the computer and the player should start out at the same amount of health (such as 100), and should be able to choose between the three moves:
- The first move should do moderate damage and has a small range (such as 18-25).
- The second move should have a large range of damage and can deal high or low damage (such as 10-35).
- The third move should heal whoever casts it a moderate amount, similar to the first move.
- After each move, a message should be printed out that tells the user what just happened, and how much health the user and computer have. Once the user or the computer's health reaches 0, the game should end.
- Subgoals:
- When someone is defeated, make sure the game prints out that their health has reached 0, and not a negative number.
- When the computer's health reaches a set amount (such as 35%), increase it's chance to cast heal.
- Give each move a name.
A Variation of 21
If you do not know how 21 (AKA Blackjack) is played, reading the first couple of paragraphs of this wikipedia article may be beneficial.
In this project, you will make a game similar to Blackjack. In this version:
- There is only one player.
- There are two types of scores: the game score and the round score.
- The game score will begin at 100, and the game will last for five rounds.
- At the beginning of the round, the player is given two random cards from a deck and they will be added together to make the player's round score.
- From here, the player has two options - draw another card to try to get their round score closer to 21, or they can end the round.
- The player can draw as many cards as they want until they end the round or their round score exceeds 21.
- At the end of the round, the difference between 21 and the round score is subtracted from the game score, and then the next round begins. After the five rounds, the player is given their total score and the game is over. ---Other Information About The Game---
- Aces are only worth 1.
- If a player busts, 21 is subtracted from their total score.
- All face cards are worth 10.
- So the point of your program is to allow the user to play the game described above.
- Subgoals:
- At the beginning of each round, print the round number (1 to 5).
- Since this is a text base game, tell the user what is happening. For example, tell him/her when he/she draws a card, the name of the card, when they bust, etc.
- Create a ranking system at the end of the game and tell the user their rank. For example, if the player finishes with 50-59 points they get an F, 60-69 is a D, 70-79 is a C, 80-89 is a B, and 90-100 is an A.
- At the end of each round, print out the user's total score.
- This may be the hardest part of the project, depending on how you wrote it. Make sure the deck has 4 of each type of card, and then remove cards as they are drawn. At the end of each round, make the deck have all of the cards again.
Compare Recent reddit Karma
Since we're all redditors here, let's make something dealing with reddit. If you go to a user's profile and add .json to the end of it, you can get the all sorts of Json data about the user (think of Json as a giant dictionary of smaller dictionaries and lists). For example, if I go to my own profile and view it's Json data, it would look like this[1]. At first it might look intimidating, but if you break it down, you can see it's just one giant dictionary with all sorts of information about my latest posts.
- Create a program that gets information about two different users, and then sees whose most recent post received the most karma.
- The program should then print out which user received more karma, and what the difference was.
- This is a pretty open project, so I encourage you to take it further by adding more features if you find it interesting.
- Remember - Elements in a list are referenced by their index numbers while entries in a dictionary are referenced by their keys.
- Subgoals:
- Allow the user to put in the name of two different users when the program first begins.
- If one of the names of the users does not exist (because of a spelling error), print out a message saying so.
- Allow the user to keep comparing other users until the program is closed.
- Display the amount of upvotes and downvotes each user received for their posts.
- Not sure how to turn json data into usable python data? Check this out.
Watch for new TIL facts
If you finished the previous project which compared the karma of two new comments, hopefully you learned a thing or two about receiving data from Reddit's API. Now you're going to take this a step further, and even have the opportunity to make a basic twitter bot.
- Create a program that receives data from the /r/todayilearned subreddit, and looks for new facts that have been posted.
- Each time the program comes across a new fact, the fact should be printed into the command line. However, phrases like "TIL ", "TIL that", etc should be removed so the only thing that is printed is the fact.
There are a couple things to note about this since you'll more than likely be using a loop to check for new posts. According to Reddit's API Access Rules Page, the API pages are only updated once every thirty seconds, so you'll have to have your code pause for at least thirty seconds before it tries to find more posts. Secondly, if for some reason you decide to try to get data sooner than every thirty seconds, make sure to not send more than thirty requests per minute. That is the maximum you are allowed to do.
There is actually a lot you can do once your program starts receiving facts. Instead of simply printing the facts, here are some ideas for what you can do with them. If you currently do not feel like you can accomplish these ideas, feel free to come back later when you have more experience.
- Print the link to the source of the fact too.
- Try to further clean up the fact by adding punctuation to the end if it is missing, capitalize the first word, etc.
- Write the facts to a separate text file so you end up with a giant compilation of random facts.
- Create a bot that posts the facts to twitter. This may sound hard, but it's actually pretty simple by using the Python Twitter Tools module and following the guide posted here.
- Remember, the maximum amount of characters you can use in a tweet is only 140, so you'll have to filter out facts that are longer than that.
- By now you should be pretty familiar with python, so if you get ideas for improving your program, go for it!
Random Wikipedia Article
If you've been to Wikipedia, you may have noticed that there is a link to a random article on the left side of the screen. While it can be fun to see what article you get taken to, sometimes it would be nice to see the name of the article so you can skip it if it sounds boring. Luckily, Wikipedia has an API that allows us to do so Click here. However, there is a dilemma. Since Wikipedia has articles about topics from all over the world, some of them have special characters in the title. For example, the article about the spanish painter Erasto Cortés Juárez has é and á in it. If you look at this specific article's API, you will see that the title is "Erasto Cort\u00e9s Ju\u00e1rez" and that the \u00e9 and \u00e1 are replacing the two previously mentioned letters. (For information about what this is, start by checking out the first half of this page in the documentation). To make your program work, you're going to have to handle this problem somehow.
- Create a program that pulls titles from the official Wikipedia API and then asks the user one by one if he or she would like to read about that article.
- Example:
- If the first title is Reddit, then the program should ask something along the lines of "Would you like to read about Reddit?" If the user says yes, then the program should open up the article for the user to read.
- HINT: Click here to see how the article's ID can be used to access the actual article.
- Subgoals:
- As mentioned before, do something about the possibility of unicode appearing in the title.
- Whether you want your program to simply filter out these articles or you want to actually turn the codes into readable characters, that's up to you.
- Make the program pause once the user has selected an article to read, and allow him or her to continue browsing different article titles once finished reading.
- Allow the user to simply press ENTER to be asked about a new article.
What’s the Weather?
If you would like to know the basics of what an API is, check out this post by iamapizza.
- Create a program that pulls data from OpenWeatherMap.org and prints out information about the current weather, such as the high, the low, and the amount of rain for wherever you live.
- Subgoals:
- Print out data for the next 5-7 days so you have a 5 day/week long forecast.
- Print the data to another file that you can open up and view at, instead of viewing the information in the command line.
- If you know html, write a file that you can print information to so that your project is more interesting. Here is an example of the results from what I threw together.[3]
- Tips:
- APIs that are in Json are essentially lists and dictionaries. Remember that to reference something in a list, you must refer to it by what number element it is in the list, and to reference a key in a dictionary, you must refer to it by it's name.
- Don't like Celsius? Add &units=imperial to the end of the URL of the API to receive your data in Fahrenheit.
Sierpinski Triangle
The Sierpinski triangle (also with the original orthography Sierpinski), also called the Sierpinski gasket or the Sierpinski Sieve, is a fractal and attractive fixed set with the overall shape of an equilateral triangle, subdivided recursively into smaller equilateral triangles. Originally constructed as a curve, this is one of the basic examples of self-similar sets, i.e., it is a mathematically generated pattern that can be reproducible at any magnification or reduction. It is named after the Polish mathematician Waclaw Sierpinski, but appeared as a decorative pattern many centuries prior to the work of Sierpinski.
Task in hand :
-
create and visualize a fractal generator that forms a standard sierpinski triangle.
-
perform this using recursive calls.
-
Subgoals :
- Also accept depth for which the fractal should be generated.
Two Numbers
Given an array of integers, return indices of the two numbers such that they add up to a specific target. You may assume that each input would have exactly one solution, and you may not use the same element twice.
Example:
Given nums = [2, 7, 11, 15], target = 9,
Because nums[0] + nums[1] = 2 + 7 = 9,
return [0, 1].
Chickens and Rabbits
Write a program to solve a classic ancient Chinese puzzle: We count 35 heads and 94 legs among the chickens and rabbits in a farm. How many rabbits and how many chickens do we have?
Hint: Use for loop to iterate all possible solutions.
FLAMES Game
Write a program which implements Flames.
Flames is an interesting game that people play to learn about their relationships. Flames is named after the acronym: Friends, Lovers, Affectionate, Marriage, Enemies, and Siblings. It is a popular game among young people, especially those beginning to explore the world of crushes. Learn more about Flames here or here
Pomodoro Timer
Create a Pomodoro Timer.
Pomodoro Timer is a time management method. The technique uses a timer to break down work into intervals, traditionally 25 minutes in length, separated by short breaks. These intervals are named pomodoros, the plural in English of the Italian word pomodoro (tomato), after the tomato-shaped kitchen timer that Cirillo used as a university student. There are six steps in the original technique:
Decide on the task to be done. Set the pomodoro timer (traditionally to 25 minutes). Work on the task. End work when the timer rings and put a checkmark on a piece of paper. If you have fewer than four checkmarks, take a short break (3–5 minutes), then go to step 2. After four pomodoros, take a longer break (15–30 minutes), reset your checkmark count to zero, then go to step 1. to know more about Pomodoro Timer click here
Scarne's Dice
Turn-based dice game where players score points by rolling a die and then: if they roll a 1, score no points and lose their turn, if they roll a 2 to 6: add the rolled value to their points choose to either reroll or keep their score and end their turn. The winner is the first player that reaches (or exceeds) 100 points.
GoogleCase
- Its a game which allows you to play with english sentences.
- User will enter a sentence in any format.(uppercase or lowercase or a mix of both)
- Program must convert the given sentence in google case .What is a google case style of sentence?[know_about_it_here:]( It is a style of writing where we replace all lower case letters into upper case letters leaving the initial of all the words).
- Subgoals:
- Program must then convert the given sentence in camel case.To know more about camel case click_here
- Sentence can be entered with any number of spaces.
Hint: If you are dealing with languages such as c then consider the sentences as the char array.
Solutions
- aekanshd
- Everstalk
- NickSchmiek
- luangthomas
- sumedhpd
- hilkenbremen
- zakaer
- anuragkumarak95
- AnanyaTyagi
- aviral36
- avantikasharma
- mattcarmody
- ayseenver
- sdmaes18
- jclane
- uityh
- Sudz
- MKJM2
- chuckytah
- Nikhil
- Brad135971
- spiraldancer
- parthkandpal
- mark-quinn
- Vishnu-Kaladharan
- Helkat
- My3bka
- vishal-vardhan
- hc65100
- areetaw
- madelinecodes
- Recandi
- tmug94
- oscarada87
- jelenam86
- vpatyal
Contributing
Contributing to this repository in any way is encouraged.
Some ways to contribute are:
- Adding solutions
- Adding new projects to the project list
- Editing the README
Contributing Solutions
- Create a new repository called
beginner-project-solutions
(or some variation thereof). - Add at least one project solution to that repository.
- Add a link to your new repository at the end of the list in the Solutions section of this README with your GitHub username.
Credits
Most of these project ideas were originally created on reddit where the original links are officially maintained here. The projects in this repository that are not in that list have been added by this project's contributors.