Report
Report
Report
On
Submitted to the
(B.Sc. CS)
Under the guidance of
Assistant Professor
1
TABLE OF CONTENTS
Page
S. No. Title
No
Introduction
1.1 Objectives
1 1.2 Project Overview
1.3 Key Features of Python
4 Development Stages
5 Error Handling
6 User Interface
7 Source code
8 Output setup
9 Conclusion
10 Futurenhancement
11 References
2
3
INTERNSHIP COMPLETION CERTIFICATE
4
FACULTY OF SCIENCE & HUMANITIES
Ramapuram
______________________________________________________________
____
Certified that this project report titled Rolling DiceSTUDENT RESULT Project
using Python is the bonafide work of HARICHARAN S. S (RA2331005020092HB
PANDISELVAM (RA2331005020033) who carried out the project work under my
supervision during the academic year 2024-2025 Semester III.
Course Code:
Course Name:
Certified further, that to the best of my knowledge, the work reported here does
not form part of any other project report on the basis of which a degree or award was
conferred on an earlier occasion on this or any other candidate.
5
ABSTRACT
This program is a simple Python-based application designed to manage and display the
exam results of students in a straightforward and efficient way. It utilizes a dictionary to
store information about each student, including their name, roll number, and marks
obtained in three subjects: math, science, and English. Through an interactive user
interface in the terminal, users can add new student records, view the exam results of
individual students based on their roll numbers, and calculate their total marks and
percentage. This abstract discusses the structure of the program, its functionality, and its
potential applications in managing student performance records.
The core of the program revolves around a dictionary called student_results, which is
designed to store the results of students. Each student's information is stored as a nested
dictionary, with their roll number serving as the key. This structure is highly efficient for
retrieving student details quickly based on their roll number, as dictionary lookups in
Python are performed in constant time, making the program scalable for large
numbers of students.
This program is designed to manage and display student exam results efficiently using
Python. It allows users to add student details, including their name, roll number, and marks
in three subjects: Math, Science, and English. The program stores this information in a
dictionary with the roll number as the key for easy retrieval. Users can view the results of
individual students by entering their roll number, and the program calculates and displays
the total marks and percentage based on the inputted scores. The user interface is menu-
driven, offering options to add students, display results, and exit the program. The system
is designed to be simple, allowing for easy management of student data and
result tracking.
6
1. Introduction
1.1 Objectives
The main objective of this project is to develop a simple, user-friendly program that can
store, display, and manage student exam results. The system is designed to capture student
names, roll numbers, and marks in three subjects (Math, Science, and English) and
calculate their total marks and percentage. This program provides a useful tool for small
academic institutions to track and manage student results effectively.
Key objectives:
Develop a Python-based system for storing student exam results.
Ensure that the system can calculate total marks and percentage for individual
students.
Implement a user-friendly interface for adding and retrieving student data.
Provide options to handle input validation and error handling effectively.
7
Extensive Libraries: Although this project is simple, Python offers many libraries
for future expansion, including GUI frameworks such as Tkinter.
2. Literature Review
Student management systems have evolved with the growing need for schools and
universities to handle vast amounts of student data. Traditional systems involve manual
record keeping, but advancements in programming and automation have led to the
development of computerized student management systems. Previous studies show that
automating these processes enhances data accuracy and significantly reduces
administrative workload.
Python-based systems, particularly those involving basic data storage and retrieval, have
gained popularity due to Python's readability and extensive support for libraries. This
project builds on these foundations by offering a lightweight, console-based solution for
managing exam results.
Literature Review: Student Exam Result Management Systems
Student performance tracking and result management have been crucial in educational
systems for decades. Traditionally, academic results were manually recorded and
managed, often leading to inefficiencies, errors, and a time-consuming process for both
educators and students. With the advent of computerized systems, digital methods for
recording and analyzing student performance have become increasingly prominent. These
systems have evolved significantly, driven by the need for accuracy, efficiency, and real-
time accessibility.
In their early stages, student result management systems were basic, often limited to
spreadsheets and simple database software like Microsoft Excel or Access. These tools
allowed educators to maintain digital records of student results, calculate totals, and
provide limited statistical analyses. While these systems were an improvement over
manual methods, they were still prone to errors during data entry and lacked scalability for
large institutions (King et al., 2000).
8
Recent advancements in programming and web technologies have led to the creation of
more user-friendly and interactive platforms for managing student data. These systems
often include features for real-time result access, data visualization, and even predictive
analytics to identify students who may need additional support (Siemens, 2013). For
example, educational management systems now incorporate artificial intelligence (AI) and
machine learning algorithms to predict student performance trends, providing actionable
insights to educators (Baker & Siemens, 2014).
The program in question, designed to store and display student results using a dictionary-
based approach, aligns with the principles of these early digital systems. While it is a
simpler version of modern SIS, it demonstrates essential functionalities, such as storing
student records, calculating totals, and displaying individual performance metrics. The use
of dictionaries as a data structure in Python allows for efficient data retrieval, especially
when managing small to moderate sets of student records. However, as the number of
students grows, the need for more sophisticated database management systems, such as
SQL-based systems, becomes apparent (Elmasri & Navathe, 2010).
In conclusion, the evolution of student result management systems highlights the ongoing
need for accuracy, efficiency, and accessibility in academic performance tracking. The
program presented offers a basic yet effective method for managing small-scale student
data, and with further development, it could be scaled to include more advanced features
found in modern educational management systems. Continued advancements in this field
will likely focus on enhancing user experience, integrating predictive analytics, and
improving accessibility through cloud-based solutions and mobile applications.
1. Install Python:
Download and install Python from the official website
https://www.python.org/downloads.
2. IDE Setup:
Use an IDE such as PyCharm, VS Code, or even a simple text editor for writing the
code.
4. Methodology
4.1 System Design
9
The Student Exam Result Program consists of two core functionalities:
Add Student: Allows users to input a student’s name, roll number, and marks in
three subjects.
Display Results: Allows users to retrieve a student's results by their roll number,
displaying the total marks and percentage.
The system is designed with a dictionary to store student data, where the roll number acts
as the key, and the student's details (name, marks) are stored as values.
4.2 Implementation
The program implements two main functions:
1. add_student(): This function gathers user input for student name, roll number, and
marks. It stores the data in the student_results dictionary.
2. display_results(): This function retrieves and displays the stored results for a
particular roll number, calculating the total marks and percentage.
5. Development Stages
5.1 Code Structure and Flow
The program is designed to follow a simple structure:
A main loop continuously prompts the user to add new student data or display
results.
Depending on user input, the appropriate function is called to either add or retrieve
student information.
2. Add Student:
Prompts the user to input the student's name, roll number, and marks.
3. Display Results:
Takes the roll number and retrieves the student’s data, calculating total marks and
percentage.
4. Exit:
Terminates the program.
10
Error handling is implemented using simple checks:
Input Validation:
Ensures that valid numbers are entered for roll numbers and marks.
Roll Number Check:
Ensures that the entered roll number exists before displaying results.
python
Copy code
def add_student():
try:
name = input("Enter student name: ")
roll_no = int(input("Enter student roll number: "))
math_marks = float(input("Enter math marks: "))
science_marks = float(input("Enter science marks: "))
english_marks = float(input("Enter english marks: "))
if roll_no in student_results:
print("Student already exists!")
return
student_results[roll_no] = {
"name": name,
"math": math_marks,
"science": science_marks,
"english": english_marks
}
print("Student added successfully!")
except ValueError:
print("Invalid input! Please enter correct values.")
11
The development of the Student Exam Result Program follows a clear set of stages,
ensuring that it effectively meets its objectives of storing and retrieving student results.
Below are the key stages involved in developing the program:
2. Design
At this stage, the structure of the program was designed. A dictionary (student_results) was
chosen as the primary data structure to store student data. Each student's roll number acts
as the key, and the value is another dictionary storing the student's name and marks. This
structure was selected because it allows quick lookups using roll numbers. The decision
was also made to use a simple, menu-driven command-line interface, allowing users to
either add student details or display the results by choosing respective options.
The two main functions of the program were also outlined in this stage:
add_student(): This function collects input from the user and stores it in the student_results
dictionary.
display_results(): This function retrieves and displays the data for a given roll number,
including calculated total marks and percentage.
3. Implementation
During the implementation phase, the program was developed in Python. The dictionary
structure for storing student data was implemented, and two main functions were created:
Input validation: The input process for roll numbers, names, and marks was added, though
error handling for invalid inputs was minimal at this stage.
Result calculation: The program computes total marks and the percentage using basic
arithmetic and displays the result for a given student.
The menu-driven interface was implemented in the main() function, allowing the user to
loop through options such as adding students, displaying results, or exiting the program.
12
4. Testing
Once the initial code was implemented, testing was carried out to ensure that the program
behaved as expected:
Functional testing: The core functionalities were tested by adding multiple students and
ensuring their details were correctly stored and retrieved.
Edge cases: Scenarios such as entering a roll number that doesn’t exist and inputting
incorrect data types (e.g., letters instead of numbers) were tested, though more robust error
handling was left for further development.
During this stage, minor bugs, such as input errors and formatting issues in the output,
were corrected.
5. Enhancements
After testing, certain improvements were identified for future development:
Error handling: Adding better error messages when a user inputs invalid data, such as
non-numeric marks or roll numbers.
Scalability: While the dictionary works well for small sets of students, for larger datasets,
migrating to a more robust database system (like SQLite) would improve performance.
Additional Features: Potential future features include viewing all students' results at once,
storing data to a file for persistence, and adding subject-specific grade analysis.
6. Deployment
The program, as it stands, is ready for use in small-scale scenarios, such as personal use or
within a small class environment. It can be run directly from a Python interpreter, making
it accessible for users with basic Python knowledge. The simplicity of the program allows
for easy modification or expansion as necessary.
13
In conclusion, the development stages of the program focused on simplicity and
functionality, ensuring that the basic requirements were met while providing a framework
for future enhancements. The program is functional and easily extensible, making it a
useful tool for small-scale student result management.
7. User Interface
The program operates in a console-based environment, offering a simple user interface:
Add Student: Allows users to input student information.
Display Results: Fetches and displays stored results using the roll number as the
key.
While the current version is a text-based interface, future enhancements could include
adding a graphical user interface (GUI) using Tkinter.
The User Interface (UI) for the Student Exam Result Program is designed to be simple and
text-based, making it easy for users to interact with the system. Since the program is
14
command-line driven, users can enter their choices and data via textual prompts. Below is
a breakdown of the key components of the UI:
1. Menu-Driven Interface
The program starts by presenting a clear menu with three options:
Add Student
Display Results
Exit
This interface is printed to the console and continuously loops until the user chooses to
exit. Users are prompted to input a number corresponding to their choice. The menu
ensures that the program is intuitive and easy to use, even for individuals with minimal
technical skills.
Example Menu:
markdown
Copy code
1. Add Student
2. Display Results
3. Exit
Enter your choice:
2. Adding Student Information
When the user selects "Add Student," the program prompts the user to input specific
information about the student:
Student Name
Roll Number
Marks for Math, Science, and English
Each input request is clear and to the point, ensuring that the user understands what
information is required. The data is stored once all fields are provided.
15
Example Input for Adding a Student:
mathematica
Copy code
Enter student name: John Doe
Enter student roll number: 101
Enter math marks: 88
Enter science marks: 92
Enter english marks: 85
After adding a student, the program confirms the success of the operation with a simple
message:
Copy code
Student added successfully!
3. Displaying Results
When the user selects "Display Results," they are asked to input the roll number of the
student whose results they want to view. The program then retrieves and displays the
stored information, including the name, marks for each subject, total marks, and the
percentage score.
mathematica
Copy code
Enter student roll number: 101
Output Example:
yaml
Copy code
Name: John Doe
Math Marks: 88
Science Marks: 92
16
English Marks: 85
Total Marks: 265
Percentage: 88.33%
If the roll number does not exist, the program alerts the user with:
Copy code
Student not found!
Example Output
Adding a Student
User chooses to add a student:
mathematica
1. Add Student
2. Display Results
3. Exit
Enter your choice: 1
Enter student name: John Doe
Enter student roll number: 101
Enter math marks: 85
Enter science marks: 90
Enter english marks: 88
Student added successfully!
Displaying Student Results
User chooses to display results for the added student:
yaml
1. Add Student
2. Display Results
3. Exit
Enter your choice: 2
Enter student roll number: 101
Name: John Doe
Math Marks: 85.0
17
Science Marks: 90.0
English Marks: 88.0
Total Marks: 263.0
Percentage: 87.66666666666667%
Handling Non-existent Roll Number
User tries to display results for a roll number that doesn't exist:
mathematica
1. Add Student
2. Display Results
3. Exit
Enter your choice: 2
Enter student roll number: 102
Student not found!
Exiting the Program
User decides to exit the program:
markdown
1. Add Student
2. Display Results
3. Exit
Enter your choice: 3
18
4. Error Handling (Basic)
Although the current interface lacks robust error handling, it handles invalid choices in the
main menu. If the user enters an invalid menu option, the program displays an error
message and prompts them to try again.
Copy code
Invalid choice!
5. Exiting the Program
To exit the program, the user can select the "Exit" option from the menu. This terminates
the loop, and the program ends gracefully, requiring no further action from the user.
8. Future Enhancements
Future enhancements for this program could include:
1. Graphical User Interface (GUI): Implementing a GUI using Tkinter or PyQt to
make the program more user-friendly.
19
2. Database Integration: Storing student results in a database (e.g., SQLite, MySQL)
for scalability and better data management.
3. Additional Features: Adding more subject options, class ranking systems, and
report generation for individual students.
4. Data Visualization: Using libraries such as Matplotlib to display graphs or charts of
student performance over time.
Future Enhancements for the Student Exam Result Program
While the current Student Exam Result Program is functional and meets basic
requirements, several future enhancements can be made to improve its usability,
scalability, and feature set. Here are potential enhancements:
1. Data Persistence
Problem: Currently, student data is stored in a dictionary in memory. When the program is
terminated, all data is lost.
Enhancement: Implement file handling or database integration (e.g., SQLite or MySQL) to
save student data. This would allow the program to persist data across sessions and handle
larger sets of student records.
Benefit: Users will be able to store and retrieve student results even after closing the
program.
2. Input Validation and Error Handling
Problem: The program lacks proper input validation, which can lead to issues like crashes
if non-numeric data is entered where numbers are expected.
Enhancement: Add validation for inputs, ensuring that the roll number is a unique integer
and marks are within valid ranges (e.g., 0-100). Also, implement exception handling (e.g.,
using try-except blocks) for better error handling.
Benefit: This would prevent users from entering incorrect data, improving the program’s
robustness.
3. Search and Display All Students' Results
Problem: Currently, users must input a specific roll number to view a student’s results.
There’s no way to view all students at once.
Enhancement: Add an option to list all students along with their details and results, or
allow searching by name in addition to roll number.
Benefit: This feature would provide an overview of all students and make it easier to find
records.
4. Grade Calculation
20
Problem: The program only calculates total marks and percentage but does not provide a
grading system.
Enhancement: Implement a grading system where students are assigned grades (A, B, C,
etc.) based on their percentage.
Benefit: This will offer a more comprehensive result summary, making it easier to assess
student performance.
5. User-Friendly Interface
Problem: The current user interface is entirely text-based, which may not be user-friendly
for all.
Enhancement: Introduce a graphical user interface (GUI) using libraries like Tkinter or
PyQt to make the program more visually intuitive. Alternatively, a web-based interface
could be developed using frameworks like Flask or Django.
Benefit: A GUI would enhance the user experience by making the program more
accessible and easier to navigate, particularly for non-technical users.
6. Export and Import of Data
Problem: There is no way to export student data for reporting purposes or import data
from external sources.
Enhancement: Add functionality to export student results to CSV or Excel files, and
import data from similar files. This would allow teachers or users to generate reports
easily and integrate the data with other systems.
Benefit: This would be useful for sharing results with students or administrators and would
also facilitate bulk data entry.
7. Subject-Wise Analytics
Problem: The current program only calculates total and percentage but does not offer
deeper insights into performance.
Enhancement: Add functionality to generate subject-wise performance analytics, such as
class averages, highest/lowest scores in each subject, or trends over time (if results are
updated periodically).
Benefit: This would allow teachers or users to better understand student performance
across subjects, helping identify strengths and weaknesses.
8. Advanced Search and Filters
Problem: Users can only search for results by roll number, which limits flexibility.
Enhancement: Add advanced search options, such as filtering students by name,
percentage range, or grades. Users could search for all students who scored above a certain
percentage, for example.
Benefit: This would allow users to filter and sort student data more effectively, especially
in scenarios with large datasets.
21
9. Multi-User Access with Authentication
Problem: The current program is designed for single-user access, with no user
authentication or roles.
Enhancement: Add a multi-user system where different users (e.g., teachers, students) can
log in with different roles and permissions. For example, teachers can add/edit results,
while students can only view their own results.
Benefit: This would enhance the program’s security and allow it to be used in larger,
shared environments such as schools.
10. Cloud Integration
Problem: The program is currently run locally and does not support remote access.
Enhancement: Integrate the program with cloud storage or databases, allowing users to
access the system from multiple locations via the internet.
Cloud integration is a vital enhancement for modern applications, including the Student
Exam Result Program. By utilizing cloud services, the program can achieve scalability,
accessibility, and data security, making it suitable for use in educational institutions.
Below is a detailed overview of how cloud integration can be implemented, its benefits,
and potential cloud service options.
Choice of Database: To store student results in the cloud, a cloud-based database service
such as Amazon RDS, Google Cloud Firestore, or Microsoft Azure SQL Database can be
utilized. These databases allow for scalable and managed storage solutions.
Data Structure: The student data structure can be modeled similarly to the current
dictionary format but will be stored in a relational or NoSQL database format, depending
on the chosen service.
b. Backend Development
API Development: A backend application can be developed using frameworks like Flask,
Django, or Node.js to interact with the cloud database. This application will provide
RESTful APIs for the frontend to perform operations such as adding student results,
retrieving data, and running queries.
Cloud Functions: For serverless architecture, cloud functions (e.g., AWS Lambda, Google
Cloud Functions) can be utilized to handle operations without the need for managing
server infrastructure.
c. Frontend Integration
22
Web Interface: A web-based frontend can be developed using HTML, CSS, and JavaScript
frameworks like React or Angular. This interface will interact with the cloud-based
backend via the APIs to perform actions such as adding students or displaying results.
User Authentication: Implementing user authentication and authorization can secure
access to the application, ensuring that only authorized users (like teachers or
administrators) can add or modify data.
As the number of students increases, cloud solutions provide the flexibility to scale
resources up or down based on demand. This eliminates concerns about local storage
limitations and server capacity.
b. Accessibility
Cloud integration allows users to access the program from any device with an internet
connection. This is particularly useful for educators who may need to input results from
different locations or students checking their grades online.
c. Data Security and Backup
Cloud providers offer robust security features, including encryption, data backup, and
disaster recovery solutions. This ensures that sensitive student data is protected and can be
restored in case of data loss.
d. Collaboration
Multiple users can access and manage student data simultaneously, facilitating better
collaboration among educators and administrative staff.
e. Cost-Effectiveness
23
Amazon RDS: For relational database management.
AWS Lambda: For running serverless functions to process requests.
b. Google Cloud Platform (GCP)
Internet Dependency: Users must have a reliable internet connection to access the
application.
Data Privacy: Institutions must ensure compliance with data protection regulations, such
as FERPA (Family Educational Rights and Privacy Act) or GDPR (General Data
Protection Regulation).
Cost Management: It’s essential to monitor usage and costs associated with cloud
resources to avoid unexpected charges.
Conclusion
Integrating cloud services into the Student Exam Result Program can significantly enhance
its capabilities and user experience. By leveraging cloud databases, API development, and
secure access controls, the program can become a powerful tool for managing student
results in a scalable and accessible manner. This enhancement not only prepares the
application for future growth but also aligns it with modern educational technology trends,
ultimately benefiting students, educators, and administrative staff.
Benefit: This would provide flexibility for remote access and make the program more
scalable, suitable for use in larger educational institutions.
Conclusion
These enhancements would significantly improve the functionality, scalability, and
usability of the Student Exam Result Program, transforming it from a basic text-based
application to a more robust, user-friendly, and feature-rich system. Incorporating these
features would make the program suitable for broader use in educational institutions and
enable better student result management.
24
9. Conclusion
The Student Exam Result Program provides a simple yet effective solution for managing
student data. By utilizing Python’s built-in features, the project demonstrates how data can
be stored and retrieved efficiently using dictionaries. With the potential for future
enhancements like a GUI and database integration, the system can be expanded to handle
more complex scenarios. The project achieves its primary goal of creating a functional
student result management system while showcasing the power and flexibility of Python.
functional, basic system that efficiently stores and retrieves student data, providing
calculations for total marks and percentage. However, several potential enhancements,
such as data persistence, improved error handling, user-friendly interfaces, advanced
search options, and grade analytics, would significantly improve its usability and
scalability. By integrating these features, the program could evolve into a comprehensive
tool suitable for larger-scale use, such as in schools or institutions. These future
improvements will not only enhance the user experience but also provide better insights
into student performance and facilitate more efficient result management.
10. References
1. Python Official Documentation: https://docs.python.org/3/
2. Handling Dictionaries in Python:
https://www.w3schools.com/python/python_dictionaries.asp
3. Error Handling in Python: https://docs.python.org/3/tutorial/errors.html
4. Tkinter for GUI: https://docs.python.org/3/library/tkinter.html
This report covers all aspects of the Student Exam Result Program, from its initial concept
to its implementation and potential future improvements.
4o
25