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
33 changes: 33 additions & 0 deletions cs205_final_exam.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
# TODO: Modify this file to create a shell script that is able to use awk to go through a file formatted like pokemon.dat and provides a printed report in the following format (where your script correctly calculates the values that go into the [VALUE] placeholders):
# ======= SUMMARY OF POKEMON.DAT ======
# Total Pokemon: [VALUE]
# Avg. HP: [VALUE]
# Avg. Attack: [VALUE]
# ======= END SUMMARY =======

# The "Avg." values should be calculated as mean values for the corresponding columns.
# The spacing and header formatting should match the above formatting description exactly.
# There should be a comment explaining the purpose of each line in your shell script.
# The data file will be passed in to the script as a positional parameter and will not necessarily be called pokemon.dat. However, you can assume that any file passed to this script will be formatted exactly the way pokemon.dat is formatted.
#!/bin/bash

# This script reads a file formatted like pokemon.dat and provides a summary report.

# Store the filename in a variable
filename=$1

# Calculate the total number of Pokemon
total_pokemon=$(awk 'END {print NR}' $filename)

# Calculate the average HP
avg_hp=$(awk '{hp_total+=$2} END {print hp_total/NR}' $filename)

# Calculate the average Attack
avg_attack=$(awk '{attack_total+=$3} END {print attack_total/NR}' $filename)

# Print the summary report
echo "# ======= SUMMARY OF $filename ======"
echo "# Total Pokemon: $total_pokemon"
echo "# Avg. HP: $avg_hp"
echo "# Avg. Attack: $avg_attack"
echo "# ======= END SUMMARY ======="
Loading