In this chapter, we are going to become familiar with the following concepts and programming techniques:
- How to work with data types and variables, which are necessary when processing numbers and strings.
- How to print a result on the console.
- How to read user input.
- How to do simple arithmetic operations: addition, subtraction, multiplication, division, string concatenation.
- How to round numbers.
We know that computers are machines that process data. All data is held in the computer memory (RAM) as variables. Variables are named areas of the computer memory which hold data of a certain type, for example, a number or text. Each variable in Python has a name and value. Here is how to define a variable, assigning a value to it at the time of declaration:
After processing, data is still held in variables (i.e. somewhere in the computer memory, allocated by our program).
In programming, each variable stores a certain value of a particular type. For example, data types can be: number, letter, text (string), date, color, image, list and others. Here are some examples of data types and their values:
- int - integer: 1, 2, 3, 4, 5, ...
- float - floating-point number: 0.5, 3.14, -1.5, ...
- str - text (string) of symbols: 'a', 'Hello', 'Hi', 'Beer', ...
- datetime - date: 21-12-2017, 25/07/1995, ...
In Python, the data type is defined by the value that is assigned and is not explicitly specified when declaring variables (as opposed to C#, Java and C++).
To print text, numbers, or another result on the screen, we need to call the built-in function print()
. It allows us to print the value of a variable as well as to directly print a string or a number:
print(9) # prints a number
print('Hello!') # prints text
msg = 'Hello, Python!'
print(msg) # prints value of a variable
To read a user input as an integer, it is necessary to declare a variable and use the built-in functions input (…)
to read a text line from the console and int (…)
to convert a text value to numerical:
num = int(input())
If it weren't for this conversion, for the program every number will be just text with which we wouldn't be able to do arithmetic operations. When using input(…)
we can include a prompt to the user to tell them what we want them to enter, for example:
size = int(input('Enter the size = '))
Let's take the following program as an example. It reads an integer, multiplies it by itself (i.e. squares it) and prints the result of the multiplication. This is how we can calculate the area of a square by using a given length of its side a:
a = int(input('a = '))
area = a * a
print('Square area = ', area)
Here is how the program would work for a square with a side equal to 3:
Try to type in an invalid number, for example "hello". You will receive an error message during the execution of the program (exception). This is normal. We will find out later how we can catch such errors and make the user re-enter a number.
The first line a = int(input('a = '))
prints a message which tells the user to input the side of the square a, then it reads a text (string) and converts it into an integer (this is called parsing) utilizing the function int(…)
. The result is assigned to a variable with the name a
.
The next command area = a * a
assigns to a new variable area
the result of the multiplication of a
by a
.
The last line print('Square area = ', area)
prints the given text and next to it, the calculated area of the square, held in the variable area
is concatenated.
Test your solution here: https://judge.softuni.org/Contests/Practice/Index/1047#0.
When we want to read several numbers from the console, if they are given each on a new line, we read them sequentially like this:
num1 = input()
num2 = input()
num3 = input()
print(num1, num2, num3)
If we type in the following input:
10
20
30
we will receive the following result:
10 20 30
When we want to read several numbers from the console and they are given together on the same line, separated by an interval, we can use the following construction:
num1, num2, num3 = map(int, input().split())
print(num1 + num2 + num3)
If we type in the following input:
100 200 300
we will receive the following result:
600
How does the code mentioned above work? By using .split(…)
we separate the elements from the given text line by the interval separator. If we type in the input from above, we will receive 3 elements: '100'
, '200'
, and '300'
. After that, utilizing the function map(int, elements)
we convert the sequence of elements from text to numbers.
To read a user input as a floating-point number, we need to declare a variable, this time using the function float(…)
which converts the given text value to a fractional number:
num = float(input())
Let's write a program that reads a fractional number in inches and converts it to centimeters:
inches = float(input('Inches = '))
centimeters = inches * 2.54
print('Centimeters = ', centimeters)
Let's start the program and make sure that when we input a value in inches, we receive the correct result in centimeters:
Test your solution here: https://judge.softuni.org/Contests/Practice/Index/1047#1.
To read a text (string) from the console, again, we have to declare a new variable and use the standard command for reading a text from the console:
str = input()
Let's write a program that asks the user for their name and salutes them with the text "Hello, {name}!".
name = input()
print('Hello, ', end='')
print(name, end='!')
By default, the built-in function print(…)
prints the result and continues to the next line. This is because print(…)
uses the parameter end
, which by default has a value \n
(new line). To stay on the same line, we can change the value of end=''
.
Here is the result if we call the function with the name "John":
Test your solution here: https://judge.softuni.org/Contests/Practice/Index/1047#2.
When printing text, numbers and other data, we can concatenate them by using templates {0}
, {1}
, {2}
, etc. In programming, these templates are called placeholders.
In Python we use the built-in method .format(…)
, through which we list the variables we want to put in place of the templates (placeholders). Example: we type in first name and last name of a student as well as their age and hometown and we print text in the format “You are {name} {family name}, a {age}-year-old person from {hometown}.”. The following is a solution with text templates:
first_name = input()
last_name = input()
age = int(input())
town = input()
print('You are {0} {1}, a {2}-year-old person from {3}.'
.format(first_name, last_name, age, town))
Here is the result that we will get after the execution of this example:
Note how each variable must be passed in the order, in which we want it to print. Essentially, the template (placeholder) accepts all types of variables and this creates great convenience when printing.
Test your solution here: https://judge.softuni.org/Contests/Practice/Index/1047#3.
It is possible for one number of a template to be used several times and it is not required for the templates of the function .format(…)
to be numbered consecutively. Here is an example:
print('{1} + {1} = {0}'.format(1+1, 1))
The result is:
1 + 1 = 2
Let's examine the basic arithmetic operations in programming.
We can sum numbers by using the +
operator:
a = 5
b = 7
sum = a + b # the result is 12
Subtracting numbers is done with the -
operator:
a = int(input())
b = int(input())
result = a - b
print(result)
Here is the result of the execution of this program (with numbers 10 and 3):
For multiplication of numbers we use the *
operator:
a = 5
b = 7
product = a * b # 35
Dividing numbers is done with the /
operator.
Note: Dividing by 0 causes an error during execution (runtime exception) - ZeroDivisionError.
Here are a few examples with the division operator:
print(10 / 2.5) # Result: 4
print(10 / 4) # Result: 2.5
print(10 / 6) # Result: 1.6666666666666667
print(5 / 0) # Result: ZeroDivisionError: division by zero
print(-5 / 0) # Result: ZeroDivisionError: division by zero
print(0 / 0) # Result: ZeroDivisionError: division by zero
print(2.5 / 0) # Result: ZeroDivisionError: float division by zero
To raise to power in Python the operator **
is used:
print(2 ** 10) # 1024
print(2 ** 20) # 1048576
print(2 ** 30) # 1073741824
print(2 ** 64) # 18446744073709551616
print(2 ** 128) # 340282366920938463463374607431768211456
print(2.5 ** 1.5) # 3.952847075210474
As seen in the example, Python works efficiently with big integer values, without special requirements. Here is a bigger example:
print(2 ** 1024)
The result is the following big integer:
179769313486231590772930519078902473361797697894230657273430081157732675805500963132708477322407536021120113879871393357658789768814416622492847430639474124377767893424865485276302219601246094119453082952085005768838150682342462881473913110540827237163350510684586298239947245938479716304835356329624224137216
Besides for summing numbers, the operator + is also used for joining pieces of text (concatenation of two strings one after another). In programming, joining two pieces of text is called "concatenation". Here is how we can concatenate a text with a number using the + operator:
first_name = 'Maria'
last_name = 'Ivanova'
age = 19
str = first_name + ' ' + last_name + ' @ ' + str(age)
print(str) # Maria Ivanova @ 19
In Python, we cannot directly concatenate a number to a given text, so we first parse the number to text utilizing the str (…)
function.
Here is another example:
a = 1.5
b = 2.5
sum = 'The sum is: ' + str(a) + str(b)
print(sum) # The sum is 1.52.5
Did you notice something strange? Maybe you expected the numbers a
and b
to be summed? The concatenation works from left to right and the result above is correct. If we want to sum the numbers, we have to use brackets, to change the order of execution of the operations:
a = 1.5
b = 2.5
sum = 'The sum is: ' + str(int(a + b))
print(sum) # The sum is: 4
The operator *
can be used to repeat a given text a number of times:
text = 'hi'
print(3 * text) # hihihi
This feature of the operator for multiplication can lead to the following wrong result if we don't keep in mind our value type:
count = input() # Enter 20
print(5 * count) # 2020202020, not 100
If we want to multiply a number read from the console by 5, we first have to convert it to an integer using the function int()
:
count = int(input()) # Enter 20
print(5 * count) # 100
In Python, there are several ways to print formatted text, i.e. text, combined with numbers, values of variables, and expressions. We have already encountered some of them, but let's look at the issue in more detail.
When printing using print(…)
we can list multiple values with commas:
width = 5
height = 7
print('width =', width, '; height =', height, '; area =', width * height)
The result is the following:
width = 5 ; height = 7 ; area = 35
As you can see from the example, in such printing every two values of the listed are separated by an interval.
We already know how to concatenate text and numbers with the operator +
. Using +
, the example above can be written in the following way:
width = 5
height = 7
print('width = ' + str(width) + ' ; height = ' + str(height) + ' ; area = ' + str(width * height))
The result is the same as in the last example:
width = 5 ; height = 7 ; area = 35
Because in Python text cannot be directly concatenated with numbers, they first have to be parsed to text using the function str(num)
.
Printing with templates can be done with formatting strings (also used in C and Java). Here is an example:
width = 5
height = 7
text = "area"
print('width = %d ; height = %d ; %s = %d' % (width, height, text, width * height))
In the example above we use the operator %
, which substitutes values in a text template, given as a sequence of elements in brackets. The following main placeholders are used (formatting strings): %d
signifies an integer, %f
signifies a floating-point number, %s
signifies text. The outcome of the code above is the same as in the last examples:
width = 5 ; height = 7 ; area = 35
Using a wrong formatting string could result in an error.
When formatting floating-point numbers, we can round them to a specified number of digits after the decimal point, for example with the formatting string %.2f
we can print a floating-point number rounded to 2 digits after the decimal point:
print('price = %.2f \nVAT = %.3f' % (1.60, 1.60 * 0.2))
The result from the code above is the following:
price = 1.60
VAT = 0.320
In the example above we use the special symbol \n
, which means „go to the next line“. Analogically, the special symbol \b
returns the cursor with one position backward (deletes the last printed symbol), respectively the following code:
print('ab\bc')
prints the following result:
ac
We already looked at how we can format text and numbers using .format(…)
and numbered templates {0}
, {1}
, {2}
etc. Actually, when enumeration is not necessary, we can use just {}
, to create a placeholder. Here is an example of how we can use formatting with text.format(…)
to print the result from the last example:
width = 5
height = 7
print('width = {} ; height = {} ; area = {}'.format(width, height, width * height))
The result is the same again:
width = 5 ; height = 7 ; area = 35
Maybe the easieast, the most intuitive and the shortest way to format text and numbers in Python is to use the f-string syntax:
width = 5
height = 7
print(f'width = {width} ; height = {height} ; area = {width * height}')
Using the F-String formatting is very easy: we put a prefix f
in front of the string and insert values of variables and expressions in curly braces {expression}
in random positions. In the example above we have three expressions: {width}
, {height}
and {width * height}
which are calculated and are substituted by their text value. We can use text expressions, integer expressions, floating-point expressions, and all other kinds of expressions.
Formatting with F-String in Python is the recommended method for printing formatted text because it uses the shortest syntax and the code is easily read and understood.
In programming, we can calculate numerical expressions, for example:
expr = (3 + 5) * (4 – 2) # 16
The standard rule for priorities of arithmetic operations is applied: multiplication and division are always done before addition and subtraction. In the case of an expression in brackets, it is calculated first, but we already know all of that from school math.
Write a program, that reads a first name, last name, age and city from the console and prints a message of the following kind: You are <firstName> <lastName>, a <age>-year-old person from <town>
.
We add to the existing PyCharm project one more Python file named "concatenate_data". We write the code which reads the input from the console:
The code, which prints the message described in the condition of the task, is purposefully blurred and must be added by the reader:
Next, the solution should be tested locally using [Ctrl + Shift + F10] or with right-click - [Run] and enter sample input.
Test your solution here: https://judge.softuni.org/Contests/Practice/Index/1047#3.
Let's write a program that inputs the lengths of the two bases of a trapezoid and its height (one floating-point number per line) and calculates the area of the trapezoid by the standard math formula:
b1 = float(input())
b2 = float(input())
h = float(input())
area = (b1 + b2) * h / 2
print('Trapezoid area = ' + str(area))
Because we want the program to work for both integer and floating-point numbers, we use float(…)
. If we start the program and we input for the sides respectively 3
, 4
and 5
, we will get the following result:
Test your solution here: https://judge.softuni.org/Contests/Practice/Index/1047#4.
Sometimes when we work with floating-point numbers we need to convert the numbers to the same type of format. This conversion is called rounding. Python offers several methods for rounding of numbers:
math.ceil(…)
- rounding up, to the next (bigger) integer number:
up = math.ceil(23.45) # up = 24
math.floor(…)
- rounding down, to the previous (smaller) integer number:
down = math.floor(45.67) # down = 45
round(…)
- rounding is done following the basic rule for rounding - if the decimal part is less than 5, the rounding is down and vice versa, if it is greater than 5 - up:
round(5.439) # 5
round(5.539) # 6
round(…, [number of symbols after the decimal point])
- rounding to the closest number with a specified number of symbols after the decimal point:
round(123.456, 2) # 123.46
round(123, 2) # 123.0
round(123.456, 0) # 123.0
round(123.512, 0) # 124.0
Let's write a program that, when given the radius r of a circle, calculates the area and the perimeter of the circle.
Formulas:
- Area = π * r * r
- Perimeter = 2 * π * r
- π ≈ 3.14159265358979323846…
import math
r = float(input('Enter circle radius => r = '))
area = math.pi * r * r
perimeter = 2 * math.pi * r
print('Area = ', area)
print('Perimeter = ', perimeter)
Let's try the program with radius r = 10
:
Test your solution here: https://judge.softuni.org/Contests/Practice/Index/1047#5.
A rectangle is given with coordinates of its two opposite corners. You have to calculate its area and perimeter:
For this exercise, we have to take into consideration that by subtracting the smaller x
from the bigger x
we can get the long side of the rectangle. Analogically, by subtracting the smaller y
from the bigger y
, we can get the height of the rectangle. Finally, we have to multiply them. Here is an example implementation of the described logic:
x1 = float(input())
y1 = float(input())
x2 = float(input())
y2 = float(input())
width = max(x1, x2) - min(x1, x2)
height = max(y1, y2) - min(y1, y2)
area = width * height
perimeter = 2 * (width + height)
print('Area = ', area)
print('Perimeter = ', perimeter)
The function max(a, b)
is used to find the bigger value between a
and b
and analogically min(a, b)
- to find the smaller value between the two.
When starting the program with the values from the coordinate system, the following result is given:
Test your solution here: https://judge.softuni.org/Contests/Practice/Index/1047#6.
Let's summarize what we have learned in this chapter:
- Reading text:
str = input()
. - Reading an integer:
num = int(input())
. - Reading a floating point number:
num = float(input())
. - Calculations with numbers and using the suitable arithmetic operators [+, -, *, /, ()]:
sum = 5 + 3
. - Printing a text by placeholders on the console:
print('{0} + {1} = {2}'.format(3, 5, 3 + 5))
.
Let's strengthen the knowledge gained throughout this chapter with a few more exercises.
We have to create a new project in PyCharm (from [Create New Project] or [File] -> [New Project]) to better organize our problems for exercise. The idea of this project is for it to contain one Python file for each problem of the exercises:
- We start PyCharm.
- We create a new project: [Create New Project] (or [File] -> [New Project]).
Write a program that reads from the console aside and a height of a triangle and calculates its area. Use the formula for triangle area: area = a * h / 2. Round the result to 2 digits after the decimal point using round(area, 2)
.
Input | Output |
---|---|
20 30 |
Triangle area = 300 |
15 35 |
Triangle area = 262.5 |
7.75 8.45 |
Triangle area = 32.74 |
1.23456 4.56789 |
Triangle area = 2.82 |
Test your solution here: https://judge.softuni.org/Contests/Practice/Index/1047#7.
Write a program that reads degrees on the Celsius scale (°C) and converts them to degrees on the Fahrenheit scale (°F). Look on the Internet for a proper formula to do the calculations. Round the result to 2 digits after the decimal point.
Input | Output |
---|---|
25 | 77 |
0 | 32 |
-5.5 | 22.1 |
32.3 | 90.14 |
Test your solution here: https://judge.softuni.org/Contests/Practice/Index/1047#8.
Write a program, that reads an angle in radians (rad
) and converts it to degrees (deg
). Look for a proper formula on the Internet. The number π in Python programs is available through math.pi
but before that, we have to refer to the math library using import math
. Round the result to the nearest integer number using the method round()
.
Input | Output |
---|---|
3.1416 | 180 |
6.2832 | 360 |
0.7854 | 45 |
0.5236 | 30 |
Test your solution here: https://judge.softuni.org/Contests/Practice/Index/1047#9.
Write a program for the conversion of US dollars (USD) to Bulgarian leva (BGN). Round the result to 2 digits after the decimal point. Use a fixed rate between a dollar (USD) and a lev (BGN): 1 USD = 1.79549 BGN.
Input | Output |
---|---|
20 | 35.91 BGN |
100 | 179.55 BGN |
12.5 | 22.44 BGN |
Test your solution here: https://judge.softuni.org/Contests/Practice/Index/1047#10.
Write a program for conversion of money from one currency to another. It has to support the following currencies: BGN, USD, EUR, GBP. Use the following fixed currency rates:
Exchange Rate | USD | EUR | GBP |
---|---|---|---|
1 BGN | 1.79549 | 1.95583 | 2.53405 |
The input is the sum for conversion, input currency, and output currency. The output is one number – the converted value of the above currency rates rounded 2 digits after the decimal point.
Input | Output |
---|---|
20 USD BGN |
35.91 BGN |
100 BGN EUR |
51.13 EUR |
12.35 EUR GBP |
9.53 GBP |
150.35 USD EUR |
138.02 EUR |
Test your solution here: https://judge.softuni.org/Contests/Practice/Index/1047#11.
Write a program that enters a birth date in the format dd-MM-yyyy
and calculates the date on which 1000 days are turned since this birth date and prints it in the same format.
Input | Output |
---|---|
1995-02-25 | 20-11-1997 |
2003-11-07 | 02-08-2006 |
2002-12-30 | 24-09-2005 |
2012-01-01 | 26-09-2014 |
1980-06-14 | 10-03-1983 |
- Look for information about the data type
datetime
in Python and in particular look at the methodsstrptime(str, format)
,timedelta(days=n)
. With their help, you can solve the problem without the need to calculate days, months, and leap years. - Don't print anything additional on the console except for the wanted date!
Test your solution here: https://judge.softuni.org/Contests/Practice/Index/1047#12.
To exercise working with variables and calculations with operators and numerical expressions, we will make something interesting: we will develop a desktop application with a graphical user interface. We will use calculations with floating-point numbers in them.
We need to create a graphical application (GUI application), that calculates the value in Euro (EUR) of monetary amount given in Bulgarian leva (BGN). We use a fixed rate BGN / EUR: 1.95583.
Note: This exercise goes beyond the material learned in this book and aims not to teach you how to program GUI applications, but to strengthen your interest in software development. Let's get to work.
We add to the existing PyCharm project one more Python file. We name it "BGN_to_EUR_converter". To create a Graphical Application using Python we will use the standard library tkinter.
First, we create a Graphical Application, which represents a rectangle Frame for components. At this stage, everything will be done without explanations, as if it is magic:
Now we can add the components of our application to the so-called function which we will call with the function init, or the so-called constructor:
We order the following UI components:
- Label - will serve for a static display of text
- Entry - will input the value for conversion
- Button - will convert the given value
- One more Label will show the result of the conversion.
Our components are found in the function create_widgets()
. We add text for visualization on the first Label, named label
. numberEntry
is Entry where the conversion value will be input. convertButton
will catch an event and execute command (in our task it will call the function convert()
which we will write shortly). output
is our Label for displaying a result after we have input a value and we have clicked a button:
After we have initialized our components, we have to visualize them. This is easly done using the built-in method from tkinter - pack()
:
It is left to write the code (program logic) for conversion from leva to euro. We will do this by using the function convert()
:
def convert(self):
entry = self.numberEntry.get()
value = float(entry)
result = round(value * 1.95583, 2)
self.output.config(
text=str(value) + ' BGN = ' + str(result) + ' EUR',
bg="green", fg="white")
On the last line, we input the result of our Label output
and we set the color of the background (bg
) and the color of the text (fg
).
We run the application with [Ctrl + Shift + F10] or with right-click + [Run], and we test if it works correctly.
We will have a problem with this code. What will happen if we input something different than a number?
We can catch this error and prompt a user-friendly message in our application. To do this, let's change the code of our program logic:
def convert(self):
entry = self.numberEntry.get()
try:
value = float(entry)
result = round(value * 1.95583, 2)
self.output.config(
text=str(value) + ' BGN = ' + str(result) + ' EUR',
bg="green", fg="white")
except ValueError:
self.output.config(
text="That's not a number!",
bg="red", fg="black")
This way we catch the error in a try block and when we input something different than a number we will receive a message That's not a number!.
Finally, we run the application with [Ctrl + Shift + F10] or with right-click + [Run] and we test if it works correctly.
Create a fun graphical application “catch the button”. Upon moving the mouse cursor onto the button, it moves to a random position. This way it creates the impression that "the button runs from the mouse and it is hard to catch". When the button gets “caught”, a congratulations message is shown.
We will begin with the same code from our last exercise. Let's change the name of our application to Catch the Button! and this time we will set the window size:
We will have the following components:
- Button - the button which we have to catch.
- Label - the congratulations message.
We create a button containing the text "Catch me!" and command - the function on_click()
, which we will define later. We visualize the components by using the method pack()
. Let both components be on the top (top):
In our examples, we will use the so-called binding operation. This represents catching of a change and executing a specified function. Using this code we instruct our program to execute the function on_enter()
when the mouse cursor is over the button and to execute the function on_leave()
when the mouse cursor leaves the button:
To move the button to a random position we use random
:
Let's implement the three functions which represent the program logic in our application:
on_enter(self, event)
- we select randomx
andy
coordinates which will change every time we move our cursor over the button; we also change the location of the button - in our example it will be static to the right, but you can create your logic and change the direction of the button together with the random numbers selected for coordinates.on_leave(self, event)
- when the cursor of the mouse is not over the button, our congratulation should not appear; we configure our label to not have text.on_click()
- when we click the button, our label will now display text - You win!.
Not everything may run smoothly from the first try. These exercises above go beyond the material learned and their purpose is to strengthen your interest and make you search the web and look for solutions to the emerging problems.
If you are having problems with the tasks above, feel free to ask questions in the SoftUni's Reddit Community: https://www.reddit.com/r/softuni/.