前提・実現したいこと
csvファイルを読み込み、そこにあるナンバーと生年月日を照合したいです。
ファイルにはそれ以外にいくつかデータを含んでいるため、辞書ではなく2次元リストで扱おうと考えています。
二次元リストのままでは要素の検索ができなかったため、
1.ナンバーを1次元リストに出力
2.ナンバーのインデックスを取得
3.生年月日のインデックスで照合
という順序でやろうとしました。
発生している問題・エラーメッセージ
・リストの要素に引用符(””)がついてしまうが、邪魔。
・リスト内の要素を数値にしたい。
・検索がうまくいかない。
n = numbers.index("'" + str(inumber) + "'") ValueError: "'100000000001'" is not in list
該当のソースコード
python
1import csv 2import numpy as np 3import pandas as pd 4 5#Reservation 6print("Your Individual Number:") 7inumber = int(input()) 8while inumber < 100000000000 or inumber > 1000000000000 : 9 print("Invalid number. Please try again.") 10 inumber = int(input()) 11 12print("Your birth year and date (yyyymmdd):") 13ibirth = int(input()) 14 15 16 17#check ID and birth year 18with open("mynumber.csv", mode="r") as rf: 19 reader = csv.reader(rf) 20 header = next(reader) 21 id_data = [row for row in reader] 22 print(id_data) 23rf.close() 24 25 26numbers = [r[0] for r in id_data] 27print(numbers) 28n = numbers.index("'" + str(inumber) + "'") 29 30 31 32if id_data[n][5] == str(ibirth) : 33 print("Authentication is completed. You can reserve a vaccination.") 34else: 35 print("Invalid ID or birth date. Please try again.")
試したこと
引用符の削除など試しましたがうまくいきません。
なぜnot in listになってしまうのかわかりません。
照合さえできればいいので他にやり方があればご教授願います。
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。