Python CSV needs to be re-read in before each "dict" operation -


इस सवाल का पहले से ही एक उत्तर है: < / P>

  • 2 जवाब

मैं csv का उपयोग कर रहा हूँ DictReader को एक सीएसवी फ़ाइल में पढ़ना और इसके साथ डिक्ट ऑपरेशन करना। अजीब बात ये है कि प्रत्येक ऑपरेशन से पहले मुझे सीएसवी फ़ाइल पढ़नी होगी। क्यों ऐसा मामला है?

  आयात सीएसवी रीडिन = ओपन ("न्यूनतम सीसीवी", "आर") dict = csv.DictReader (रीडिन, डेलीमीटर = ",", कोटेशन = "\ "" '' 'एक', 'शीर्षक 2': 'दो', 'दो', '' 'शीर्षक 3': 'तीन'} {'शीर्षक 1': 'चार', 'शीर्षक 2': 'पांच', 'शीर्षक 3': 'छः'}  

अगर मैं प्रिंट ऑपरेशन करता हूं दूसरी बार:

  शब्दकोशों में पंक्तियों के लिए: प्रिंट पंक्तियों  

यह कुछ भी नहीं लौटाता है, यहां तक ​​कि कोई त्रुटि भी नहीं। मुझे एक और दो चरणों का पालन करने की ज़रूरत है ( "ओपन" और "सीएसवी। डेकट रीडर") फिर से प्रिंट आउट आउट प्राप्त करने के लिए। यह क्यों है?

इसे दूसरी बार काम नहीं करने का कारण यह है कि फ़ाइल सूचक फ़ाइल के अंत में पहले से है, इसलिए पढ़ने के लिए कुछ नहीं है; आपका पाठक ऑब्जेक्ट फ़ाइल के अंत में पहले ही पहुंच चुका है।

वैसे, dict को एक चर नाम के रूप में प्रयोग न करें, यह अंतर्निहित dict () फ़ंक्शन को छाया करता है। < / P>

आप एक सूची में सभी पंक्तियों को स्टोर कर सकते हैं, ताकि आपको फ़ाइल को फिर से पढ़ना पड़े:

  खुले ('minimal.csv', 'r ') के रूप में रीडिंग: पंक्तियों में पंक्ति के लिए रीडर = सीएसवी। डिक्टराइडर (रीडिन, डेलीमीटर =', ', कोटेशन = "\" ") पंक्तियां = सूची (रीडर): प्रिंट (पंक्ति)  
< / div>

Comments

Popular posts from this blog

java - Can't add JTree to JPanel of a JInternalFrame -

c# - How to know the number of Threads created and limit the Tasks accordingly -

asp.net mvc - How to attach sql database to a javascript graph -