Pharmacy Management System Using Python Django
data:image/s3,"s3://crabby-images/0a976/0a97629f30fc63deef346f7c948bd19bc8714482" alt="Pharmacy Management System Using Python"
Introduction
The Pharmacy Dispensing Management System is a robust and user-friendly software solution developed using Python and the Django framework. It is designed to streamline the workflows in a pharmacy setting by facilitating the management of patients, prescriptions, medications, and administrative tasks. The system serves multiple user roles, including Administrator, Pharmacist, Doctor, Receptionist (Pharmacy Clerk), and Patient, each with distinct functionalities tailored to their responsibilities.
This project aims to address inefficiencies in manual pharmacy operations, such as tracking stock levels, dispensing errors, and managing patient data. With its intuitive interface and comprehensive features, it simplifies day-to-day operations, ensuring that medications are dispensed accurately and efficiently.
Key Features:
Administrator: Manage admissions, users, prescriptions, drug categories, stocks, and personal accounts.
Pharmacist: Handle drug inventory, stocks, dispensing drugs, and patient feedback.
Doctor: Create and manage patient prescriptions.
Receptionist: Manage patient admissions and their personal account details.
Patient: View prescribed medications, provide feedback on pharmacy services, and manage personal accounts.
The system ensures seamless communication among different users and integrates all pharmacy-related operations into a single platform. Its user-friendly design allows both technical and non-technical users to navigate and perform their tasks effectively.
How to Run the Code
To get the Pharmacy Dispensing Management System running on your local machine, follow these steps:
Prerequisites:
Ensure you have Python and pip installed on your system. Install Django and other dependencies from the requirements.txt
file.
Steps:
Clone or download the project: Extract the project files into a directory on your system.
Navigate to the project directory:
cd pharmacy-management-system-master
Install required dependencies: Use the following command to install all required Python libraries:
pip install -r requirements.txt
Apply migrations to set up the database: Initialize the SQLite database by running:
python manage.py migrate
Run the development server: Start the Django server with the command:
python manage.py runserver
Access the application: Open your web browser and navigate to
http://127.0.0.1:8000/
to interact with the system.
Default Login Credentials:
Administrator:
Username:
admin
Password:
1234
Pharmacist:
Username:
pharmacist1
Password:
1234
Doctor:
Username:
doctor1
Password:
1234
Receptionist:
Username:
pharmacyclerk1
Password:
1234
Patient:
Username:
patient1
Password:
1234
Code Explanation
The project is built on the Django framework, which follows the Model-View-Controller (MVC) architecture. Let’s explore some key components of the code:
1. User Roles and Authentication:
Each user role is managed with Django’s built-in authentication system. The roles include specific permissions and access levels.
from django.contrib.auth.models import AbstractUser
class CustomUser(AbstractUser):
role = models.CharField(max_length=20, choices=[
('Administrator', 'Administrator'),
('Pharmacist', 'Pharmacist'),
('Doctor', 'Doctor'),
('Receptionist', 'Receptionist'),
('Patient', 'Patient'),
])
This CustomUser
model extends Django’s default user model to include a role
field, which defines the type of user.
2. Managing Medications:
Administrators and pharmacists can add and manage drug inventories. Below is a snippet for managing drugs:
class Drug(models.Model):
name = models.CharField(max_length=100)
category = models.ForeignKey(DrugCategory, on_delete=models.CASCADE)
quantity = models.IntegerField()
price = models.FloatField()
def __str__(self):
return self.name
This model defines the drug details, including its name, category, quantity, and price.
3. Prescription Management:
Doctors can create prescriptions for patients. Pharmacists can view and dispense medications based on these prescriptions.
class Prescription(models.Model):
patient = models.ForeignKey(CustomUser, on_delete=models.CASCADE, limit_choices_to={'role': 'Patient'})
doctor = models.ForeignKey(CustomUser, on_delete=models.CASCADE, limit_choices_to={'role': 'Doctor'})
date = models.DateField(auto_now_add=True)
def __str__(self):
return f"Prescription for {self.patient.username} by Dr. {self.doctor.username}"
The prescription model links patients to their doctors and includes a timestamp for tracking.
4. Dispensing Medications:
Pharmacists dispense medications and update stock levels accordingly.
class Dispense(models.Model):
prescription = models.ForeignKey(Prescription, on_delete=models.CASCADE)
drug = models.ForeignKey(Drug, on_delete=models.CASCADE)
quantity = models.IntegerField()
def save(self, *args, **kwargs):
# Update stock quantity
self.drug.quantity -= self.quantity
self.drug.save()
super().save(*args, **kwargs)
The Dispense
model ensures that stock levels are automatically updated whenever a medication is dispensed.
Get Discount on Top Educational Courses
Source Code:
Output:
data:image/s3,"s3://crabby-images/96952/969528a6db4e0b46ad6de53ebedb4fae723b3546" alt="Pharmacy Management System Using Python Pharmacist"
data:image/s3,"s3://crabby-images/96952/969528a6db4e0b46ad6de53ebedb4fae723b3546" alt="Pharmacy Management System Using Python Pharmacist"
data:image/s3,"s3://crabby-images/af26f/af26f15ac38ad17cf3f298fe433e5d495246f8eb" alt="Pharmacy Management System Using Python Doctor Login"
data:image/s3,"s3://crabby-images/dad9b/dad9b2abff45601e047945478c9bc27e1a9263c5" alt=""
More Projects:
data:image/s3,"s3://crabby-images/fc43f/fc43fa5139b1a033b1a153f87bab3aa7c4f39e9e" alt="Drawing Chhatrapati Shivaji Maharaj Using Python"
Drawing Chhatrapati Shivaji Maharaj Using Python using turtle Module
Drawing Chhatrapati Shivaji Maharaj Using Python Chhatrapati Shivaji Maharaj, the legendary Maratha warrior and founder of the Maratha Empire, is an inspiration to millions. His
data:image/s3,"s3://crabby-images/fd3ee/fd3eeb633112162bc5b37290487ab7049bdb37ac" alt="Resume Builder Application"
Resume builder Application using java with complete source code
Resume Builder Application using Java With Source Code Graphical User Interface [GUI] Introduction: The Resume Builder Application is a powerful and user-friendly tool designed to
data:image/s3,"s3://crabby-images/c126e/c126ede66b1528cc719b7c5916cc765f0fd325e3" alt="Encryption Tool using java"
Encryption Tool using java with complete source code
Encryption Tool using java with complete source Code GUI Introduction: The Encryption Tool is a Java-based GUI application designed to help users encrypt and decrypt
data:image/s3,"s3://crabby-images/a3204/a3204fb14d065d3cee3509be09aaad774a91740c" alt="Movie Ticket Booking System"
Movie Ticket Booking System using java with complete source Code
Movie Ticket Booking System using Java With Source Code Graphical User Interface [GUI] Introduction: The Movie Ticket Booking System is a Java Swing-based application that
data:image/s3,"s3://crabby-images/88eef/88eeff6557d4e2508f7014a11ae1a483676f374f" alt="Video Call Website Using HTML, CSS, and JavaScript (Source Code)"
Video Call Website Using HTML, CSS, and JavaScript (Source Code)
Video Call Website Using HTML, CSS, and JavaScript (Source Code) Introduction Hello friends, welcome to today’s new blog post. Today we have created a beautiful
data:image/s3,"s3://crabby-images/924fe/924fef406794801397275564aa59ca8b788b759b" alt="promise day using html CSS and JavaScript"
promise day using html CSS and JavaScript
promise day using html CSS and JavaScript Introduction Hello all my developers friends my name is Gautam and everyone is welcome to today’s beautiful blog