Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
209 changes: 209 additions & 0 deletions cfu-data-types-CLEAN.ipynb
Original file line number Diff line number Diff line change
@@ -0,0 +1,209 @@
{
"cells": [
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# CFU | Data Types"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Working with Data Types"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Objective: Practice working with different data types and their corresponding operations."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Exercise 1: Calculate remaining salary"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"In this exercise, prompt the user to enter their personal information such as name, age, address, salary, and expenses, and then perform some calculations to determine how much money they have left after expenses. \n",
"\n",
"Use data type casting to ensure that the age, salary, and expenses are stored as integers or floats, as appropriate, and round the remaining money to one decimal. \n",
"\n",
"Use a boolean variable to indicate whether the remaining salary is greater than or equal to 500. \n",
"\n",
"Finally, you will use string formatting to print a message to the screen in the following format: \n",
"\"*name*, who is *age* years old, and lives in *address* has *remaining_salary* dollars left from her salary after expenses. It is *is_salary_good* that she has more than $500 left.\", using the mentioned variables.\n",
"\n",
"*Hint:* \n",
"- *You can use the input() function to ask the user to enter their information. Beware that input() function returns a String.*\n",
"- *You can round the remaining salary to one decimal using the round() function.*\n",
"- *Use data type conversion functions. Recommended external resources: [Data type conversion](https://www.geeksforgeeks.org/type-conversion-in-python/)*"
]
},
{
"cell_type": "code",
"execution_count": 2,
"metadata": {},
"outputs": [
{
"name": "stdin",
"output_type": "stream",
"text": [
"Enter your name: María\n",
"Enter your age: 23\n",
"Enter your address: Murcia, Spain\n",
"Enter your monthly salary: 2500\n",
"Enter your monthly expenses: 1000\n"
]
},
{
"name": "stdout",
"output_type": "stream",
"text": [
"María, who is 23 years old, and lives in Murcia, Spain has 1500.0 dollars left from her salary after expenses. It is True that she has more than $500 left.\n"
]
}
],
"source": [
"# Ask the user for personal information\n",
"name = input(\"Enter your name: \")\n",
"age = int(input(\"Enter your age: \"))\n",
"address = input(\"Enter your address: \")\n",
"salary_input = input(\"Enter your monthly salary: \")\n",
"expenses_input = input(\"Enter your monthly expenses: \")\n",
"\n",
"# Clean the input by removing any non-numeric characters except decimal point\n",
"salary = float(''.join(c for c in salary_input if c.isdigit() or c == '.'))\n",
"expenses = float(''.join(c for c in expenses_input if c.isdigit() or c == '.'))\n",
"\n",
"# Calculate remaining salary\n",
"remaining_salary = round(salary - expenses, 1)\n",
"\n",
"# Boolean: does the user have at least $500 left?\n",
"is_salary_good = remaining_salary >= 50\n",
"\n",
"# Print final message using string formatting\n",
"print(f\"{name}, who is {age} years old, and lives in {address} has {remaining_salary} dollars left from her salary after expenses. It is {is_salary_good} that she has more than $500 left.\")\n"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"### Exercise 2: Text Cleaning and Concatenation"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Write code that takes text from the variable `poem`, removes the punctuation and leaves everything in lowercase. \n",
"\n",
"Concatenate the resulting string with the string \"python is awesome!\" and store the result in a new variable. \n",
"\n",
"Print the length of the new string.\n",
"\n",
"Split the string into a list of strings using the space delimiter, save it in a variable `poem_list` and print it. \n",
"\n",
"*Hint:*\n",
"\n",
"- *You can use the len() function to get the length of a string.*\n",
"- *Search string methods to accomplish the other steps. Recommended External Resources: [Python String Methods](https://www.w3schools.com/python/python_ref_string.asp)*\n",
"- *Use method chaining to simplify your code. If you are not sure what it is, read this tutorial before: https://pyneng.readthedocs.io/en/latest/book/04_data_structures/method_chaining.html*\n"
]
},
{
"cell_type": "code",
"execution_count": 10,
"metadata": {},
"outputs": [],
"source": [
"poem = \"\"\"Some say the world will end in fire,\n",
"Some say in ice.\n",
"From what I’ve tasted of desire\n",
"I hold with those who favor fire.\n",
"But if it had to perish twice,\n",
"I think I know enough of hate\n",
"To say that for destruction ice\n",
"Is also great\n",
"And would suffice.\"\"\""
]
},
{
"cell_type": "code",
"execution_count": 3,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"258\n",
"['some', 'say', 'the', 'world', 'will', 'end', 'in', 'fire', 'some', 'say', 'in', 'ice', 'from', 'what', 'ive', 'tasted', 'of', 'desire', 'i', 'hold', 'with', 'those', 'who', 'favor', 'fire', 'but', 'if', 'it', 'had', 'to', 'perish', 'twice', 'i', 'think', 'i', 'know', 'enough', 'of', 'hate', 'to', 'say', 'that', 'for', 'destruction', 'ice', 'is', 'also', 'great', 'and', 'would', 'suffice', 'python', 'is', 'awesome!']\n"
]
}
],
"source": [
"# Given poem\n",
"poem = \"\"\"Some say the world will end in fire,\n",
"Some say in ice.\n",
"From what I’ve tasted of desire\n",
"I hold with those who favor fire.\n",
"But if it had to perish twice,\n",
"I think I know enough of hate\n",
"To say that for destruction ice\n",
"Is also great\n",
"And would suffice.\"\"\"\n",
"\n",
"# Step 1–3: Remove punctuation, lowercase, and concatenate\n",
"cleaned_text = poem.replace(\",\", \"\").replace(\".\", \"\").replace(\"’\", \"\").replace(\"\\n\", \" \").lower() + \" python is awesome!\"\n",
"\n",
"# Step 4: Print length\n",
"print(len(cleaned_text))\n",
"\n",
"# Step 5: Split the string into words (by space)\n",
"poem_list = cleaned_text.split(\" \")\n",
"\n",
"# Step 6: Print the list of words\n",
"print(poem_list)\n",
"\n"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": []
}
],
"metadata": {
"kernelspec": {
"display_name": "Python [conda env:base] *",
"language": "python",
"name": "conda-base-py"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 3
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.13.5"
}
},
"nbformat": 4,
"nbformat_minor": 4
}
93 changes: 84 additions & 9 deletions cfu-data-types.ipynb
Original file line number Diff line number Diff line change
Expand Up @@ -49,11 +49,48 @@
},
{
"cell_type": "code",
"execution_count": null,
"execution_count": 2,
"metadata": {},
"outputs": [],
"outputs": [
{
"name": "stdin",
"output_type": "stream",
"text": [
"Enter your name: María\n",
"Enter your age: 23\n",
"Enter your address: Murcia, Spain\n",
"Enter your monthly salary: 2500\n",
"Enter your monthly expenses: 1000\n"
]
},
{
"name": "stdout",
"output_type": "stream",
"text": [
"María, who is 23 years old, and lives in Murcia, Spain has 1500.0 dollars left from her salary after expenses. It is True that she has more than $500 left.\n"
]
}
],
"source": [
"# Your code here\n"
"# Ask the user for personal information\n",
"name = input(\"Enter your name: \")\n",
"age = int(input(\"Enter your age: \"))\n",
"address = input(\"Enter your address: \")\n",
"salary_input = input(\"Enter your monthly salary: \")\n",
"expenses_input = input(\"Enter your monthly expenses: \")\n",
"\n",
"# Clean the input by removing any non-numeric characters except decimal point\n",
"salary = float(''.join(c for c in salary_input if c.isdigit() or c == '.'))\n",
"expenses = float(''.join(c for c in expenses_input if c.isdigit() or c == '.'))\n",
"\n",
"# Calculate remaining salary\n",
"remaining_salary = round(salary - expenses, 1)\n",
"\n",
"# Boolean: does the user have at least $500 left?\n",
"is_salary_good = remaining_salary >= 50\n",
"\n",
"# Print final message using string formatting\n",
"print(f\"{name}, who is {age} years old, and lives in {address} has {remaining_salary} dollars left from her salary after expenses. It is {is_salary_good} that she has more than $500 left.\")\n"
]
},
{
Expand Down Expand Up @@ -102,19 +139,57 @@
},
{
"cell_type": "code",
"execution_count": null,
"execution_count": 3,
"metadata": {},
"outputs": [],
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"258\n",
"['some', 'say', 'the', 'world', 'will', 'end', 'in', 'fire', 'some', 'say', 'in', 'ice', 'from', 'what', 'ive', 'tasted', 'of', 'desire', 'i', 'hold', 'with', 'those', 'who', 'favor', 'fire', 'but', 'if', 'it', 'had', 'to', 'perish', 'twice', 'i', 'think', 'i', 'know', 'enough', 'of', 'hate', 'to', 'say', 'that', 'for', 'destruction', 'ice', 'is', 'also', 'great', 'and', 'would', 'suffice', 'python', 'is', 'awesome!']\n"
]
}
],
"source": [
"# Your code here\n"
"# Given poem\n",
"poem = \"\"\"Some say the world will end in fire,\n",
"Some say in ice.\n",
"From what I’ve tasted of desire\n",
"I hold with those who favor fire.\n",
"But if it had to perish twice,\n",
"I think I know enough of hate\n",
"To say that for destruction ice\n",
"Is also great\n",
"And would suffice.\"\"\"\n",
"\n",
"# Step 1–3: Remove punctuation, lowercase, and concatenate\n",
"cleaned_text = poem.replace(\",\", \"\").replace(\".\", \"\").replace(\"’\", \"\").replace(\"\\n\", \" \").lower() + \" python is awesome!\"\n",
"\n",
"# Step 4: Print length\n",
"print(len(cleaned_text))\n",
"\n",
"# Step 5: Split the string into words (by space)\n",
"poem_list = cleaned_text.split(\" \")\n",
"\n",
"# Step 6: Print the list of words\n",
"print(poem_list)\n",
"\n"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": []
}
],
"metadata": {
"kernelspec": {
"display_name": "Python 3 (ipykernel)",
"display_name": "Python [conda env:base] *",
"language": "python",
"name": "python3"
"name": "conda-base-py"
},
"language_info": {
"codemirror_mode": {
Expand All @@ -126,7 +201,7 @@
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.9.13"
"version": "3.13.5"
}
},
"nbformat": 4,
Expand Down