前提
PythonのFor文のネストの動きがリスト形式と辞書形式では違うのかを教えていただき
かつ同じ動きにするためにはどのように対応したら良いかを教えて頂きたいです。
独学かつ初心者のため、お見苦しいソースコードではありますが、ご容赦ください。
実現したいこと
下記2つのCSVにて「No」をキーにして一致した部分を出力させたい。
For文のネストの動きをリスト形式と同じ形に動かしたい。
goods.csv
No,商品名 1,いちご 2,もも 3,すいか
price.csv
No,価格 1,350 2,100 3,800
発生している問題・エラーメッセージ
下記パスの箇所にてfor frice_csvdataが2回目以降の繰り返しが行われない。 for goods_csvdata in goods_csvline: for price_csvdata in price_csvline:
該当のソースコード
python
#import 読み込み import csv #入力データパス indir = "" #ローカルパスを指定 #goods.csvを読み込み goods_csvfile = open(indir + "goods.csv", "r", encoding ="ms932", errors = "", newline = "") #goods.csv辞書形式で取得 goods_csvline = csv.DictReader(goods_csvfile, delimiter=",", doublequote = True, lineterminator = "\r\n", quotechar = '"', skipinitialspace = True) #price.csvを読み込み price_csvfile = open(indir + "price.csv", "r", encoding ="ms932", errors = "", newline = "") #goods.csv辞書形式で取得 price_csvline = csv.DictReader(price_csvfile, delimiter=",", doublequote = True, lineterminator = "\r\n", quotechar = '"', skipinitialspace = True) #Noが一致したときに商品名と価格をあわせて表示 for goods_csvdata in goods_csvline: for price_csvdata in price_csvline: if goods_csvdata["No"] == price_csvdata["No"]: print (str(goods_csvdata["商品名"])+str(price_csvdata["価格"])) else: continue
試したこと
python
#リスト形式 a = [1,2] b = [3,4] for c in a : for d in b: print(str(c) + "," + str(d)) #print結果 1,3 1,4 2,3 2,4
print結果は想定したFor文のネストの動きとなっていた。
補足情報(FW/ツールのバージョンなど)
Python バージョン:3.10.4
ここにより詳細な情報を記載してください。
まだ回答がついていません
会員登録して回答してみよう