2

我有一个 .csv 文件,其中包含与此类似的出生日期字段:

John,Smith,34 La La Lane,14/03/85,johnsmith@email.com
Sarah,Second,42 Wallaby Way,11/06/92,sarahsecond@email.com
Third,Example,99 Peacock Terrace,04/12/89,thirdexample@email.com

我想制作一个程序,只打印在某个月份出生的条目文件中的行(在这种情况下,月份是在第一个斜线之后,即 dd/mm/yy)。

因此,如果所需的月份是 3 月,它将打印出 John Smith 的条目。

对此的任何帮助都会很棒,我已经挣扎了一段时间

4

4 回答 4

8

我不确定您正在努力解决问题的哪一部分,所以我将给出一个一般性的答案。Python 有一个 csv 阅读器,你可以像这样使用:

import csv
desiredMonth = 3
with open('people.csv', 'rb') as csvfile:
    content = csv.reader(csvfile, delimiter=',')
    for row in content:
        month = int(row[3].split('/')[1])
        if month == desiredMonth:
            # print the row or store it in a list for later printing

row已经为你分成了一个列表,row[3]生日也是如此。split()然后将月份部分分成几部分,并[1]给出第二部分,即月份。将其转换int为一个好主意,因此您可以轻松地将其与您想要的任何月份进行比较。

于 2013-02-26T23:27:33.770 回答
2

这是一种不同的方法...为了处理 csv 文件,python 包csvkit安装了许​​多命令行实用程序,可以让您非常轻松地对 .csv 文件进行切片和切块。

$ pip install csvkit

这将安装一个名为csvgrep(以及其他)的命令。

$ csvgrep -c 4 -r '\d{2}/03' yourfile.csv
First,Last,Address,Birthdate,Email
John,Smith,34 La La Lane,14/03/85,johnsmith@email.com

需要注意的一件事是,csvkit假设所有 .csv 文件都有标题行。这就是为什么csvgrep显示标题行的结果。这也意味着您必须像这样向数据文件添加标头:

First,Last,Address,Birthdate,Email
John,Smith,34 La La Lane,14/03/85,johnsmith@email.com
Sarah,Second,42 Wallaby Way,11/06/92,sarahsecond@email.com
Third,Example,99 Peacock Terrace,04/12/89,thirdexample@email.com 

命令行参数说明:

$ csvgrep -c 4 -r '\d{2}/03' yourfile.csv
-c specifies which column you want to search 
-r specifies the regular expression you want to match in the column

正则表达式 '^\d{2}/03' 将匹配以 2 位数字开头的字符串,然后是 '/',然后是月份 '03'。

查看csvkit 教程以获取更多信息。

于 2013-02-27T00:17:14.033 回答
1
import csv
with open('yourfile.csv', 'rb') as csvfile:
    spamreader = csv.reader(csvfile, delimiter=',')
    for row in spamreader:
        date = row[3]
        month = date.split('/')[1]
        if int(month) >= YOUR_MONTH_HERE
            print row
于 2013-02-26T23:30:31.723 回答
1

尽可能多的教程类型:-)

somecsvfile=r'/home/me/Desktop/txt.csv'
the_month_you_are_looking_for = 6 # as in june.
with open(somecsvfile, 'r') as fi:
    for line in fi:   
        list_from_text = line.split(',')
        bday = list_from_text[3]
        bmonth = int(bday.split('/')[1])
        if bmonth == the_month_you_are_looking_for:
            print (line)
于 2013-02-26T23:33:25.933 回答