Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimanakah Saya Boleh Mencipta Kamus Tunggal dengan Cekap daripada Fail CSV Pasangan Nilai Kunci?

Bagaimanakah Saya Boleh Mencipta Kamus Tunggal dengan Cekap daripada Fail CSV Pasangan Nilai Kunci?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-11-19 06:18:03521semak imbas

How Can I Efficiently Create a Single Dictionary from a CSV File of Key-Value Pairs?

Membuat Kamus Bersatu daripada Fail CSV Yang Terdiri daripada Pasangan Nilai Kunci Unik

Apabila mengendalikan fail CSV, satu tugas biasa ialah mencipta kamus di mana setiap baris mewakili pasangan nilai kunci yang unik. Walaupun kelas 'csv.DictReader' menyediakan cara yang mudah untuk mengulang melalui fail sedemikian baris demi baris, mencipta kamus bersatu memerlukan pendekatan yang berbeza.

Kod yang disediakan cuba membina kamus dalam gelung bersarang , membawa kepada 'ValueError' kerana cuba membongkar berbilang nilai dengan hanya dua yang dijangkakan. Untuk menangani isu ini, sintaks harus diubah suai sedikit:

Python 3:

import csv

with open('coors.csv', mode='r') as infile:
    reader = csv.reader(infile)
    with open('coors_new.csv', mode='w') as outfile:
        writer = csv.writer(outfile)
        mydict = {rows[0]: rows[1] for rows in reader}

Python 2:

import csv

with open('coors.csv', mode='r') as infile:
    reader = csv.reader(infile)
    with open('coors_new.csv', mode='w') as outfile:
        writer = csv.writer(outfile)
        mydict = dict((rows[0], rows[1]) for rows in reader)

Sintaks yang disemak ini berulang dengan betul melalui CSV fail, mengekstrak kunci dari lajur pertama dan nilai dari lajur kedua untuk setiap baris. Hasilnya ialah kamus tunggal di mana kunci adalah unik dan diperoleh daripada lajur pertama, dan nilai diperoleh daripada lajur kedua. Pendekatan ini menyatukan semua pasangan nilai kunci ke dalam kamus yang komprehensif.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mencipta Kamus Tunggal dengan Cekap daripada Fail CSV Pasangan Nilai Kunci?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn