Python Tip: Mastering
When defining a class in Python,
The
In the
Let's create some cars:
Output:
#PythonTip #OOP #Classes #InitMethod #SelfKeyword #ObjectOriented #PythonProgramming
---
By: @DataScienceQ β¨
init and self in OOP! πWhen defining a class in Python,
init is a special method (often called the constructor) that gets called automatically every time a new object (instance) of the class is created. It's used to set up the initial state or attributes of that object.The
self parameter is a convention and the first parameter of any instance method. It always refers to the instance of the class itself, allowing you to access its attributes and other methods from within the class.class Car:
def init(self, make, model, year):
self.make = make # Assign 'make' to the instance's 'make' attribute
self.model = model # Assign 'model' to the instance's 'model' attribute
self.year = year # Assign 'year' to the instance's 'year' attribute
def get_description(self):
return f"This is a {self.year} {self.make} {self.model}."
In the
init method, self.make = make means "take the value passed in as make and assign it to the make attribute of this specific Car object."Let's create some cars:
my_car = Car("Toyota", "Camry", 2020)
your_car = Car("Honda", "Civic", 2022)
print(my_car.get_description())
print(your_car.get_description())Output:
This is a 2020 Toyota Camry.
This is a 2022 Honda Civic.
init ensures each object starts with its own data, and self connects you to that data!#PythonTip #OOP #Classes #InitMethod #SelfKeyword #ObjectOriented #PythonProgramming
---
By: @DataScienceQ β¨
Python OOP Tip: Inheritance Basics! π
Inheritance allows a new class (child) to acquire properties and methods from an existing class (parent), promoting code reuse and establishing an "is-a" relationship.
Key Takeaway: Use
#Python #OOP #Inheritance #PythonTips #Programming
---
By: @DataScienceQ β¨
Inheritance allows a new class (child) to acquire properties and methods from an existing class (parent), promoting code reuse and establishing an "is-a" relationship.
class Vehicle:
def init(self, brand):
self.brand = brand
def description(self):
return f"This is a {self.brand} vehicle."
class Car(Vehicle): # Car inherits from Vehicle
def init(self, brand, model):
super().init(brand) # Call parent's constructor
self.model = model
def drive(self):
return f"The {self.brand} {self.model} is driving."
my_car = Car("Toyota", "Camry")
print(my_car.description())
print(my_car.drive())
Key Takeaway: Use
super().init() in a child class to properly initialize parent attributes when overriding the constructor.#Python #OOP #Inheritance #PythonTips #Programming
---
By: @DataScienceQ β¨
β€2
Pandas Python Tip: Custom Column Operations with
The
Key Takeaway:
#Pandas #Python #DataScience #DataManipulation #PythonTips
---
By: @DataScienceQ β¨
apply()! πThe
df.apply() method is powerful for applying a function along an axis of the DataFrame (rows or columns), especially useful for custom transformations on columns or rows.import pandas as pd
data = {'Name': ['Alice', 'Bob', 'Charlie'],
'Score': [85, 92, 78]}
df = pd.DataFrame(data)
Example: Create a new column 'Grade' based on 'Score'
def assign_grade(score):
if score >= 90:
return 'A'
elif score >= 80:
return 'B'
else:
return 'C'
df['Grade'] = df['Score'].apply(assign_grade)
print(df)
You can also use lambda functions for simpler operations
df['Score_Double'] = df['Score'].apply(lambda x: x * 2)
print(df)
Key Takeaway:
df.apply() (especially on a Series) is excellent for element-wise custom logic, often more readable than complex vectorized operations for specific tasks.#Pandas #Python #DataScience #DataManipulation #PythonTips
---
By: @DataScienceQ β¨
β€1
π NumPy Tip: Boolean Indexing (Masking) π
Ever need to filter your arrays based on a condition? NumPy's Boolean Indexing, also known as masking, is your go-to! It allows you to select elements that satisfy a specific condition.
Explanation:
A boolean array (the mask) is created by applying a condition to your original array. When this mask is used for indexing, NumPy returns a new array containing only the elements where the mask was
#NumPy #PythonTips #DataScience #ArrayMasking #Python #Programming
---
By: @DataScienceQ β¨
Ever need to filter your arrays based on a condition? NumPy's Boolean Indexing, also known as masking, is your go-to! It allows you to select elements that satisfy a specific condition.
import numpy as np
Create a sample NumPy array
data = np.array([12, 5, 20, 8, 35, 15, 30])
Create a boolean mask: True where value is > 10, False otherwise
mask = data > 10
print("Boolean Mask:", mask)
Apply the mask to the array to filter elements
filtered_data = data[mask]
print("Filtered Data (values > 10):", filtered_data)
You can also combine the condition and indexing directly
even_numbers = data[data % 2 == 0]
print("Even Numbers:", even_numbers)
Explanation:
A boolean array (the mask) is created by applying a condition to your original array. When this mask is used for indexing, NumPy returns a new array containing only the elements where the mask was
True. Simple, powerful, and efficient!#NumPy #PythonTips #DataScience #ArrayMasking #Python #Programming
---
By: @DataScienceQ β¨
Django ORM Tip:
#Django #DjangoORM #Python #Database #Optimization #Fexpressions #CodingTip
---
By: @DataScienceQ β¨
F() Expressions for Database-Level OperationsF() expressions allow you to reference model field values directly within database operations. This avoids fetching data into Python memory, making queries more efficient for updates or comparisons directly on the database.from django.db.models import F
from your_app.models import Product # Assuming a Product model with 'stock' and 'price' fields
Increment the stock of all products by 5 directly in the database
Product.objects.all().update(stock=F('stock') + 5)
Update the price to be 10% higher than the current price
Product.objects.all().update(price=F('price') 1.1)
Filter for products where the stock is less than 10 times its price
low_ratio_products = Product.objects.filter(stock__lt=F('price') 10)
#Django #DjangoORM #Python #Database #Optimization #Fexpressions #CodingTip
---
By: @DataScienceQ β¨
Hey there, fellow Django devs! Ever faced the dreaded "N+1 query problem" when looping through related objects? π± Your database might be doing way more work than it needs to!
Let's conquer it with
Example 1: Fetching Posts and their Comments
Imagine a blog where each
Example 2: Prefetching with Custom QuerySets
What if you only want to prefetch approved comments, or order them specifically? You can apply filters and ordering within
Example 3: Nested Prefetching
You can even prefetch related objects of related objects! Let's get posts, their comments, and each comment's author.
Master
#Django #DjangoORM #Python #Optimization #NPlus1 #DatabaseQueries #Performance #WebDev #CodingTip
---
By: @DataScienceQ β¨
Let's conquer it with
prefetch_related()! While select_related() works for one-to-one and foreign key relationships (joining tables directly in SQL), prefetch_related() is your go-to for many-to-many relationships and reverse foreign key lookups (like getting all comments for a post). It performs a separate query for each related set and joins them in Python, saving you tons of database hits and speeding up your app.Example 1: Fetching Posts and their Comments
Imagine a blog where each
Post has many Comments. Without prefetch_related, accessing post.comments.all() inside a loop for multiple posts would hit the database for each post's comments.from your_app.models import Post, Comment # Assuming your models are here
Bad: This would cause N+1 queries if you loop and access comments
posts = Post.objects.all()
for post in posts:
for comment in post.comment_set.all(): # database hit for EACH post
print(comment.text)
Good: Fetches all posts AND all comments in just 2 queries!
posts_with_comments = Post.objects.prefetch_related('comment_set')
for post in posts_with_comments:
print(f"Post: {post.title}")
for comment in post.comment_set.all(): # 'comment_set' is the default related_name
print(f" - {comment.text}")
Example 2: Prefetching with Custom QuerySets
What if you only want to prefetch approved comments, or order them specifically? You can apply filters and ordering within
prefetch_related() using Prefetch objects!from django.db.models import Prefetch
from your_app.models import Post, Comment # Assuming Comment has 'is_approved' and 'created_at'
Define a custom queryset for only approved comments, ordered by creation
approved_comments_queryset = Comment.objects.filter(is_approved=True).order_by('-created_at')
Fetch posts and only their approved comments, storing them in a custom attribute
posts_with_approved_comments = Post.objects.prefetch_related(
Prefetch('comment_set', queryset=approved_comments_queryset, to_attr='approved_comments')
)
for post in posts_with_approved_comments:
print(f"Post: {post.title}")
# Access them via the custom attribute 'approved_comments'
for comment in post.approved_comments:
print(f" - (Approved) {comment.text}")
Example 3: Nested Prefetching
You can even prefetch related objects of related objects! Let's get posts, their comments, and each comment's author.
from your_app.models import Post, Comment # Assuming Comment has a ForeignKey to an Author model
posts_with_nested_relations = Post.objects.prefetch_related(
# Here, we prefetch comments, and within the comments prefetch their authors
Prefetch('comment_set', queryset=Comment.objects.select_related('author'))
)
for post in posts_with_nested_relations:
print(f"\nPost: {post.title}")
for comment in post.comment_set.all():
print(f" - {comment.text} by {comment.author.name}") # Access comment.author directly!
Master
prefetch_related() to make your Django apps lightning fast! β‘οΈ Happy coding!#Django #DjangoORM #Python #Optimization #NPlus1 #DatabaseQueries #Performance #WebDev #CodingTip
---
By: @DataScienceQ β¨
π‘
#PythonTips #DataStructures #collections #namedtuple #Python
---
By: @DataScienceQ β¨
collections.namedtuple for structured data: Create simple, immutable data structures without boilerplate.from collections import namedtuple
Define a simple Point structure
Point = namedtuple('Point', ['x', 'y'])
Create instances
p1 = Point(10, 20)
p2 = Point(x=30, y=40)
print(f"Point 1: x={p1.x}, y={p1.y}")
print(f"Point 2: {p2[0]}, {p2[1]}") # Access by index
It's still a tuple!
print(f"Is p1 a tuple? {isinstance(p1, tuple)}")
Example with a Person
Person = namedtuple('Person', 'name age city')
person = Person('Alice', 30, 'New York')
print(f"Person: {person.name} is {person.age} from {person.city}")
#PythonTips #DataStructures #collections #namedtuple #Python
---
By: @DataScienceQ β¨
β€1
π‘ Python Asyncio Tip: Basic async/await for concurrent operations.
#Python #Asyncio #Concurrency #Programming
---
By: @DataScienceQ β¨
import asyncio
async def say_hello():
await asyncio.sleep(0.1) # Simulate a non-blocking I/O call
print("Hello from async!")
async def main():
await say_hello()
asyncio.run(main())
#Python #Asyncio #Concurrency #Programming
---
By: @DataScienceQ β¨
β€2
π§ NumPy Quiz: Array Shapes
Question: What will be the output of
A)
B)
C)
D)
β Correct answer: B
#NumPy #Python #DataScience #Array #Quiz
---
By: @DataScienceQ β¨
Question: What will be the output of
arr.shape for the NumPy array created by np.zeros((2, 3))?import numpy as np
arr = np.zeros((2, 3))
A)
(3, 2)B)
(2, 3)C)
6D)
(2, 3, 0)β Correct answer: B
#NumPy #Python #DataScience #Array #Quiz
---
By: @DataScienceQ β¨
π§ Quiz: Python
Q: Which of the following is the correct way to define an empty list in Python?
A) my_list = ()
B) my_list = []
C) my_list = {}
D) my_list = "None"
β Correct answer: B
Explanation: In Python, lists are defined using square brackets
#Python #DataStructures #Lists
---
By: @DataScienceQ β¨
Q: Which of the following is the correct way to define an empty list in Python?
A) my_list = ()
B) my_list = []
C) my_list = {}
D) my_list = "None"
β Correct answer: B
Explanation: In Python, lists are defined using square brackets
[]. An empty list is simply []. Parentheses () define a tuple, and curly braces {} define a set or dictionary.#Python #DataStructures #Lists
---
By: @DataScienceQ β¨
π§ Quiz: What is the fundamental data structure for all computations in PyTorch?
A) NumPy Array
B) PyTorch Tensor
C) Pandas DataFrame
D) Python List
β Correct answer: B
Explanation: PyTorch Tensors are multi-dimensional arrays, similar to NumPy arrays, but with the added ability to run on GPUs for accelerated computation and support for automatic differentiation, which is crucial for neural network training.
#PyTorch #DeepLearning #Tensors
---
By: @DataScienceQ β¨
A) NumPy Array
B) PyTorch Tensor
C) Pandas DataFrame
D) Python List
β Correct answer: B
Explanation: PyTorch Tensors are multi-dimensional arrays, similar to NumPy arrays, but with the added ability to run on GPUs for accelerated computation and support for automatic differentiation, which is crucial for neural network training.
#PyTorch #DeepLearning #Tensors
---
By: @DataScienceQ β¨
β€1π1
π§ Quiz: Which Pythonic approach is generally preferred for creating a new list by transforming elements from an existing list?
A) Using a
B) Using a list comprehension
C) Using the
D) Using a
β Correct answer: B
Explanation: List comprehensions are often more concise, readable, and generally more performant than explicit
#PythonTips #PythonicCode #ListComprehensions
---
By: @DataScienceQ β¨
A) Using a
for loop with list.append()B) Using a list comprehension
C) Using the
map() function followed by list()D) Using a
while loop with list.append()β Correct answer: B
Explanation: List comprehensions are often more concise, readable, and generally more performant than explicit
for loops or map() for creating new lists based on existing iterables. They encapsulate the iteration and creation logic cleanly.#PythonTips #PythonicCode #ListComprehensions
---
By: @DataScienceQ β¨
β€1
π‘ Python: Automated Background Removal with
To effortlessly remove backgrounds from images using Python, the
Code explanation: This script uses
#Python #ImageProcessing #BackgroundRemoval #rembg #ComputerVision
βββββββββββββββ
By: @DataScienceQ β¨
rembgTo effortlessly remove backgrounds from images using Python, the
rembg library is highly effective. It leverages pre-trained machine learning models to identify and separate foreground objects, generating images with transparent backgrounds. This is ideal for e-commerce, photo editing, or preparing assets. You'll need to install it first: pip install rembg Pillow.from rembg import remove
from PIL import Image
# Define input and output file paths
input_path = 'input_image.png' # Replace with your image file (e.g., JPEG, PNG)
output_path = 'output_image_no_bg.png'
try:
# Open the input image
with Image.open(input_path) as input_image:
# Process the image to remove background
output_image = remove(input_image)
# Save the resulting image with a transparent background
output_image.save(output_path)
print(f"Background removed successfully. New image saved as '{output_path}'")
except FileNotFoundError:
print(f"Error: Input file '{input_path}' not found. Please ensure the image exists.")
except Exception as e:
print(f"An error occurred: {e}")
Code explanation: This script uses
PIL (Pillow) to open an image and rembg.remove() to automatically detect and eliminate its background, saving the result as a new PNG with transparency. Ensure you have an input_image.png in the same directory or provide its full path.#Python #ImageProcessing #BackgroundRemoval #rembg #ComputerVision
βββββββββββββββ
By: @DataScienceQ β¨
π‘ Python: Converting Numbers to Human-Readable Words
Transforming numerical values into their word equivalents is crucial for various applications like financial reports, check writing, educational software, or enhancing accessibility. While complex to implement from scratch for all cases, Python's
Code explanation: This script uses the
#Python #TextProcessing #NumberToWords #num2words #DataManipulation
βββββββββββββββ
By: @DataScienceQ β¨
Transforming numerical values into their word equivalents is crucial for various applications like financial reports, check writing, educational software, or enhancing accessibility. While complex to implement from scratch for all cases, Python's
num2words library provides a robust and easy solution. Install it with pip install num2words.from num2words import num2words
# Example 1: Basic integer
number1 = 123
words1 = num2words(number1)
print(f"'{number1}' in words: {words1}")
# Example 2: Larger integer
number2 = 543210
words2 = num2words(number2, lang='en') # Explicitly set language
print(f"'{number2}' in words: {words2}")
# Example 3: Decimal number
number3 = 100.75
words3 = num2words(number3)
print(f"'{number3}' in words: {words3}")
# Example 4: Negative number
number4 = -45
words4 = num2words(number4)
print(f"'{number4}' in words: {words4}")
# Example 5: Number for an ordinal form
number5 = 3
words5 = num2words(number5, to='ordinal')
print(f"Ordinal '{number5}' in words: {words5}")
Code explanation: This script uses the
num2words library to convert various integers, decimals, and negative numbers into their English word representations. It also demonstrates how to generate ordinal forms (third instead of three) and explicitly set the output language.#Python #TextProcessing #NumberToWords #num2words #DataManipulation
βββββββββββββββ
By: @DataScienceQ β¨
π‘ Python Dictionary Cheatsheet: Key Operations
This lesson provides a quick, comprehensive guide to Python dictionaries. Dictionaries are unordered, mutable collections of key-value pairs, essential for mapping data. This cheatsheet covers creation, access, modification, and useful methods.
Code explanation: This script demonstrates essential Python dictionary operations. It covers various ways to create dictionaries, access values using direct key lookup and the safer
#Python #Dictionaries #DataStructures #Programming #Cheatsheet
βββββββββββββββ
By: @DataScienceQ β¨
This lesson provides a quick, comprehensive guide to Python dictionaries. Dictionaries are unordered, mutable collections of key-value pairs, essential for mapping data. This cheatsheet covers creation, access, modification, and useful methods.
# 1. Dictionary Creation
my_dict = {"name": "Alice", "age": 30, "city": "New York"}
empty_dict = {}
another_dict = dict(brand="Ford", model="Mustang") # Using keyword arguments
from_tuples = dict([("a", 1), ("b", 2)]) # From a list of key-value tuples
dict_comprehension = {i: i*i for i in range(3)} # {0: 0, 1: 1, 2: 4}
# 2. Accessing Values
name = my_dict["name"] # Alice
age = my_dict.get("age") # 30 (safer, returns None if key not found)
job = my_dict.get("job", "Unemployed") # Unemployed (default value if key not found)
# 3. Adding and Updating Elements
my_dict["email"] = "[email protected]" # Adds new key-value pair
my_dict["age"] = 31 # Updates existing value
my_dict.update({"city": "London", "occupation": "Engineer"}) # Updates/adds multiple pairs
# 4. Removing Elements
removed_age = my_dict.pop("age") # Removes 'age' and returns its value (31)
del my_dict["city"] # Deletes the 'city' key-value pair
# my_dict.popitem() # Removes and returns a (key, value) pair (Python 3.7+ guaranteed last inserted)
my_dict.clear() # Empties the dictionary
# Re-create for further examples
person = {"name": "Bob", "age": 25, "city": "Paris", "occupation": "Artist"}
# 5. Iterating Through Dictionaries
# print("--- Keys ---")
for key in person: # Iterates over keys by default
# print(key)
pass
# print("--- Values ---")
for value in person.values():
# print(value)
pass
# print("--- Items (Key-Value Pairs) ---")
for key, value in person.items():
# print(f"{key}: {value}")
pass
# 6. Dictionary Information
num_items = len(person) # 4
keys_list = list(person.keys()) # ['name', 'age', 'city', 'occupation']
values_list = list(person.values()) # ['Bob', 25, 'Paris', 'Artist']
items_list = list(person.items()) # [('name', 'Bob'), ('age', 25), ...]
# 7. Checking for Key Existence
has_name = "name" in person # True
has_country = "country" in person # False
# 8. Copying Dictionaries
person_copy = person.copy() # Shallow copy
person_deep_copy = dict(person) # Another way for shallow copy
# 9. fromkeys() - Create dictionary from keys with default value
default_value_dict = dict.fromkeys(["a", "b", "c"], 0) # {'a': 0, 'b': 0, 'c': 0}
Code explanation: This script demonstrates essential Python dictionary operations. It covers various ways to create dictionaries, access values using direct key lookup and the safer
get() method, and how to add or update key-value pairs. It also shows different methods for removing elements (pop(), del, clear()), and iterating through dictionary keys, values, or items. Finally, it illustrates how to get dictionary size, retrieve lists of keys/values/items, check for key existence, and create copies or new dictionaries using fromkeys().#Python #Dictionaries #DataStructures #Programming #Cheatsheet
βββββββββββββββ
By: @DataScienceQ β¨
β€1
π§ Quiz: Which of the following is the most Pythonic and efficient way to iterate through a list
A)
B)
C)
D)
β Correct answer: B
Explanation: The
#PythonTips #Pythonic #Programming
βββββββββββββββ
By: @DataScienceQ β¨
my_list and access both each item and its corresponding index?A)
i = 0; while i < len(my_list): item = my_list[i]; i += 1B)
for index, item in enumerate(my_list):C)
for index in range(len(my_list)): item = my_list[index]D)
for item in my_list: index = my_list.index(item)β Correct answer: B
Explanation: The
enumerate() function is specifically designed to provide both the index and the item while iterating over a sequence, making the code cleaner, more readable, and generally more efficient than manual indexing or while loops. Option D is inefficient as list.index(item) scans the list for each item, especially if duplicates exist.#PythonTips #Pythonic #Programming
βββββββββββββββ
By: @DataScienceQ β¨
π‘ Python Lists: Adding and Extending
Use
Code explanation: The code first initializes a list.
#Python #PythonLists #DataStructures #CodingTips #PythonCheatsheet
βββββββββββββββ
By: @DataScienceQ β¨
Use
.append() to add a single item to the end of a list. Use .extend() to add all items from an iterable (like another list) to the end.# Create a list of numbers
my_list = [10, 20, 30]
# Add a single element
my_list.append(40)
# my_list is now [10, 20, 30, 40]
print(f"After append: {my_list}")
# Add elements from another list
another_list = [50, 60]
my_list.extend(another_list)
# my_list is now [10, 20, 30, 40, 50, 60]
print(f"After extend: {my_list}")
Code explanation: The code first initializes a list.
.append(40) adds the integer 40 to the end. Then, .extend() takes each item from another_list and adds them individually to the end of my_list.#Python #PythonLists #DataStructures #CodingTips #PythonCheatsheet
βββββββββββββββ
By: @DataScienceQ β¨
π‘ Python Conditionals:
The
β’
β’
β’
This provides a clear and efficient way to handle multiple mutually exclusive scenarios.
Code explanation: The script evaluates the variable
#Python #ControlFlow #IfStatement #PythonTips #ProgrammingLogic
βββββββββββββββ
By: @DataScienceQ β¨
if, elif, and elseThe
if-elif-else structure allows your program to execute different code blocks based on a series of conditions. It evaluates them sequentially:β’
if: The first condition to check. If it's True, its code block runs, and the entire structure is exited.β’
elif: (short for "else if") If the preceding if (or elif) was False, this condition is checked. You can have multiple elif blocks.β’
else: This is an optional final block. Its code runs only if all preceding if and elif conditions were False.This provides a clear and efficient way to handle multiple mutually exclusive scenarios.
# A program to categorize a number
number = 75
if number < 0:
category = "Negative"
elif number == 0:
category = "Zero"
elif 0 < number <= 50:
category = "Small Positive (1-50)"
elif 50 < number <= 100:
category = "Medium Positive (51-100)"
else:
category = "Large Positive (>100)"
print(f"The number {number} is in the category: {category}")
# Output: The number 75 is in the category: Medium Positive (51-100)
Code explanation: The script evaluates the variable
number. It first checks if it's negative, then if it's zero. After that, it checks two positive ranges using elif. Since 75 is greater than 50 and less than or equal to 100, the condition 50 < number <= 100 is met, the category is set to "Medium Positive", and the final else block is skipped.#Python #ControlFlow #IfStatement #PythonTips #ProgrammingLogic
βββββββββββββββ
By: @DataScienceQ β¨
π§ Quiz: What is one of the most critical first steps when starting a new data analysis project?
A) Select the most complex predictive model.
B) Immediately remove all outliers from the dataset.
C) Perform Exploratory Data Analysis (EDA) to understand the data's main characteristics.
D) Normalize all numerical features.
β Correct answer:C
Explanation:EDA is crucial because it helps you summarize the data's main features, identify patterns, spot anomalies, and check assumptions before you proceed with more formal modeling. Steps like modeling or removing outliers should be informed by the initial understanding gained from EDA.
#DataAnalysis #DataScience #Statistics
βββββββββββββββ
By: @DataScienceQ β¨
A) Select the most complex predictive model.
B) Immediately remove all outliers from the dataset.
C) Perform Exploratory Data Analysis (EDA) to understand the data's main characteristics.
D) Normalize all numerical features.
β Correct answer:
Explanation:
#DataAnalysis #DataScience #Statistics
βββββββββββββββ
By: @DataScienceQ β¨
β€4
π§ Quiz: Which keyword is used to implement inheritance between classes in Java?
A)
B)
C)
D)
β Correct answer:B
Explanation:In Java, the keyword is used to indicate that a class is inheriting from another class, forming an "is-a" relationship. The implements keyword is used for interfaces.
#Java #OOP #Inheritance
βββββββββββββββ
By: @DataScienceQ β¨
A)
implementsB)
extendsC)
inheritsD)
usesβ Correct answer:
Explanation:
extends#Java #OOP #Inheritance
βββββββββββββββ
By: @DataScienceQ β¨