"Shopping Cart" Further Exploration Challenges
This document provides optional project challenges for students seeking a greater level of difficulty.
Configuring Sales Tax Rate
BONUS POINTS: 3-4% (RECOMMENDED)
The store owner likes your work and wants to use your app in all their regional locations. But different municipalities use different sales tax rates. Instead of hard-coding a single sales tax rate, allow each user to configure their own tax rate via an environment variable called TAX_RATE
.
NOTE: Use a ".env" file approach for managing environment variables. Your "README.md" file must contain instructions for how the user can set up their own local ".env" file, including an example of the variable assignment:
NOTE: The ".env" file must be ignored from version control, by using a corresponding entry in the ".gitignore" file.
HINT: use the
os
module in conjunction with thedotenv
packageHINT: you might need to use the
float()
function to convert the environment variable value to a float datatype, so you can perform numeric calculations with it
Handling Pricing per Pound
BONUS POINTS: 3-4%
Add a new product called "Organic Bananas" to the products inventory. Assign it a price of 0.79
, but add another attribute called something like price_per
to indicate the item is priced per "pound". Update all the other product dictionaries to match the new structure, indicating they are priced per "item".
When running the program, if the clerk inputs the identifier of the bananas (or any other item that is priced by pound), the program should ask the clerk to input the number of pounds (e.g. 2.2
), then the program should calculate the price accordingly.
Writing Receipts to File
BONUS POINTS: 3-5%
In addition to displaying a receipt at the end of the checkout process, the program should write the receipt information into a new ".txt" file saved in a new "receipts" directory inside the project repository. The clerk's printer-connected computer should be able to actually print a paper receipt from the information contained in this file.
Each text file should be named according to the date and time the checkout process started (e.g. "/receipts/2019-07-04-15-43-13-579531.txt", where the numbers represent the year, month, day, 24-hour-style hour, minute, second, and milliseconds/microseconds, respectively).
HINT: consult the notes on file management for examples of how to write to file in Python
NOTE: to prevent clutter, exclude these receipt files from being tracked in version control by creating a new ".gitignore" file in the "receipts" directory, and adding the following contents inside:
Sending Receipts via Email
BONUS POINTS: 6-8% (RECOMMENDED)
In addition to displaying a receipt at the end of the checkout process, the program should prompt the checkout clerk or the customer to indicate whether the customer would like to receive the receipt by email. And if so, it should prompt the checkout clerk or the customer to input the customer's email address, and then it should send the receipt information to the customer by email. The clerk's network-connected computer should be able to send these emails.
At the very least, the email should display the checkout timestamp and the total price. But ideally it should contain all the receipt information described in the basic requirements.
HINT: leverage the email-sending capabilities of the
sendgrid
package, and optionally use SendGrid Email Templates to further control the formatting of email contents.
Integrating with a CSV File Datastore
BONUS POINTS: 3-5%
Instead of using a hard-coded products
variable, download or copy the contents of the provided "products.csv" file into your project directory in a new subdirectory called "data" (so the path to the CSV file should be "data/products.csv"). Then update your code to read the products
from this CSV file.
HINT: leverage the capabilities of the
csv
module or thepandas
package (recommended) for CSV file management.NOTE: to prevent clutter, exclude the CSV file from being tracked in version control by creating a new ".gitignore" file within the "data" directory, and adding the following contents inside:
Integrating with a Google Sheets Datastore
BONUS POINTS: 6-8%
Instead of using a hard-coded products
variable or a "products.csv" file as the application's datastore, use this provided products Google Sheet document instead. Update your code to read the products
from this Google Sheet.
HINT: leverage the capabilities of the
gspread
package.
Integrating with a Barcode Scanner
BONUS POINTS: 0 (FOR FUN, NO WAY TO VERIFY)
Assemble a handful of real products that have barcodes.
Ask to borrow the professor's barcode scanner during class or office hours, or feel free to purchase one from Amazon.
Connect the barcode scanner to your computer's USB port, and practice scanning a few of the items, and record the resulting product identifiers.
Adapt the program's products
variable (or CSV file or Google Sheet, or whatever datastore you're using) to reflect the real products and their identifiers. For example:
NOTE: for real life products, we'll probably want to change the identifier values to strings, in case any contain alphabetic characters or leading zeros (e.g. "LIFE water" identifier above).
After modifying the product list, try re-running the program, using the barcode scanner to scan the real items. It should work!
Last updated