-
Notifications
You must be signed in to change notification settings - Fork 0
/
PyPoll_Challenge.py
161 lines (124 loc) · 5.26 KB
/
PyPoll_Challenge.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
# -*- coding: UTF-8 -*-
"""PyPoll Election Challenge Solution."""
# Add our dependencies.
import csv
import os
# Assign a variable for the file to load and the path.
file_to_load = 'Resources/election_results.csv'
# Add a variable to load a file from a path.
file_to_load = os.path.join(".", "Resources", "election_results.csv")
# Add a variable to save the file to a path.
file_to_save = os.path.join(".", "analysis", "election_analysis.txt")
# Initialize a total vote counter.
total_votes = 0
# Candidate Options and candidate votes.
candidate_options = []
candidate_votes = {}
# Create a county list and county votes dictionary.
county_names = []
county_votes = {}
# Track the winning candidate, vote count and percentage
winning_candidate = ""
winning_count = 0
winning_percentage = 0
# Track the largest county and county voter turnout.
largest_county_turnout = ""
largest_county_vote = 0
# Read the csv and convert it into a list of dictionaries
with open(file_to_load) as election_data:
reader = csv.reader(election_data)
# Read the header
header = next(reader)
# For each row in the CSV file.
for row in reader:
# Add to the total vote count
total_votes = total_votes + 1
# Get the candidate name from each row.
candidate_name = row[2]
# Extract the county name from each row.
county_name = row[1]
# If the candidate does not match any existing candidate add it to
# the candidate list
if candidate_name not in candidate_options:
# Add the candidate name to the candidate list.
candidate_options.append(candidate_name)
# And begin tracking that candidate's voter count.
candidate_votes[candidate_name] = 0
# Add a vote to that candidate's count
candidate_votes[candidate_name] += 1
# Write an if statement that checks that the
# county does not match any existing county in the county list.
if county_name not in county_names:
# Add the existing county to the list of counties.
county_names.append(county_name)
# Begin tracking the county's vote count.
county_votes[county_name] = 0
# Add a vote to that county's vote count.
county_votes[county_name] += 1
# iterated over all row in cvs files
# Save the results to our text file.
with open(file_to_save, "w") as txt_file:
# Print the final vote count (to terminal)
election_results = (
f"\nElection Results\n"
f"-------------------------\n"
f"Total Votes: {total_votes:,}\n"
f"-------------------------\n\n"
f"County Votes:\n")
print(election_results, end="")
txt_file.write(election_results)
# Write a for loop to get the county from the county dictionary.
for county in county_votes:
# Retrieve the county vote count.
county_vote = county_votes[county]
# Calculate the percentage of votes for the county.
county_percentage = float(county_vote) / float(total_votes) * 100
# Print the county results to the terminal.
county_results = (
f"{county}: {county_percentage:.1f}%: ({county_vote})\n"
)
print(county_results)
# Save the county votes to a text file.
# write f-string to txt file
txt_file.write(county_results)
# Write an if statement to determine the winning county and get its vote count.
if (county_vote > largest_county_vote):
largest_county_vote = county_vote
largest_county_turnout = county
# iterated over all counties
# Print the county with the largest turnout to the terminal.
largest_county_turnout = (
f"\n--------------------------\n"
f"Largest County Turnout: {largest_county_turnout}\n"
f"--------------------------\n\n"
)
print(largest_county_turnout)
# Save the county with the largest turnout to a text file.
txt_file.write(largest_county_turnout)
# Save the final candidate vote count to the text file.
for candidate_name in candidate_votes:
# Retrieve vote count and percentage
votes = candidate_votes.get(candidate_name)
vote_percentage = float(votes) / float(total_votes) * 100
candidate_results = (
f"{candidate_name}: {vote_percentage:.1f}% ({votes:,})\n")
# Print each candidate's voter count and percentage to the
# terminal.
print(candidate_results)
# Save the candidate results to our text file.
txt_file.write(candidate_results)
# Determine winning vote count, winning percentage, and candidate.
if (votes > winning_count) and (vote_percentage > winning_percentage):
winning_count = votes
winning_candidate = candidate_name
winning_percentage = vote_percentage
# Print the winning candidate (to terminal)
winning_candidate_summary = (
f"-------------------------\n"
f"Winner: {winning_candidate}\n"
f"Winning Vote Count: {winning_count:,}\n"
f"Winning Percentage: {winning_percentage:.1f}%\n"
f"-------------------------\n\n")
print(winning_candidate_summary)
# Save the winning candidate's name to the text file
txt_file.write(winning_candidate_summary)