私はCSVファイルからデータを読み込む小さなプログラムを開発中です。プログラムの一環として、ユーザー入力は> =のデータのみを選択するために使用されますが、TypeError:unorderable types:str()> = int()コードを実行します。スティングが整数に変換されていないように見えます。Python 3のint()関数が入力文字列を整数に変換しない
def get_csv_data(data_type, num):
import csv
ga_session_data = {}
ga_pageviews_data = {}
with open('files/data.csv', 'r') as csvfile:
reader = csv.reader(csvfile)
for row in reader:
page, sessions, pageviews = row
ga_session_data[page] = int(sessions)
ga_pageviews_data[page] = int(pageviews)
if data_type == 'sessions' and sessions >= int(num):
for page, sessions in ga_session_data.items():
print(page, ' - ', sessions)
elif data_type == 'pageviews' and pageviews >= int(num):
for page, pageviews in ga_pageviews_data.items():
print(page, ' - ', pageviews)
def main():
while(True):
question = input("Are you interested in sessions or pageviews?")
if question == 'sessions':
number = int(input("What range are you interested in?"))
get_csv_data(data_type = 'sessions', num = int(number))
elif question == 'pageviews':
number = input("What range are you interested in?")
get_csv_data(data_type = 'pageviews', num = int(number))
else:
print("Invalid Input. Choose between sessions and pageviews.")
main()
'sessions> = int(num)'では、文字列( 'sessions')とintを比較しています。 –
同じことがページビュー数=> int(num) –