5-8作业

第一题
import csv ,os

reader=csv.DictReader(open('北京高档酒店价格分析.csv','r',encoding='utf-8'))
result=list(reader)
region=[]
for x in result:
    if x['地区'] not in region:
        region.append(x['地区'])
for x in region:
    with open(rf'.\高档酒店地区分布\{x}.csv','w',encoding='utf-8',newline='') as writer:
        writer=csv.DictWriter(writer,list(result[0].keys()))
        writer.writeheader()
        for i in result:
            if i['地区']==x:
                writer.writerow(i)
def get_birth(file_path):
    reader=csv.DictReader(open(file_path,'r',encoding='utf-8'))
    result=list(reader)

    for x in result:
        a=x['birthday']
        birthday=f'{a}-{randint(1,28)}'
        birth=datetime.strptime(birthday,'%Y-%m-%d')
        x['birthday'] = birth
    return result

def ave_age(result):
    time_today = datetime.today()
    sum=0
    for x in result:
        age=time_today.year-x['birthday'].year
        sum+=age
    ave=sum/len(result)
    return  ave



def leo(result):
    with open('狮子座.csv', 'w', encoding='utf-8', newline='') as leof:
        writer = csv.DictWriter(leof, list(result[0].keys()))
        writer.writeheader()
        for x in result:
            month = x['birthday'].month
            day = x['birthday'].day
            if (month==7 and day>=23) or (month==8 and day<=22):
                writer.writerow(x)
    return

a=get_birth('2018年北京积分落户数据.csv')
print(ave_age(a))
leo(a)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值