栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

用Python排序CSV

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

用Python排序CSV

这是Alex的答案,经过重新设计以支持列数据类型:

import csvimport operatordef sort_csv(csv_filename, types, sort_key_columns):    """sort (and rewrite) a csv file.    types:  data types (conversion functions) for each column in the file    sort_key_columns: column numbers of columns to sort by"""    data = []    with open(csv_filename, 'rb') as f:        for row in csv.reader(f): data.append(convert(types, row))    data.sort(key=operator.itemgetter(*sort_key_columns))    with open(csv_filename, 'wb') as f:        csv.writer(f).writerows(data)

编辑:

我做的很蠢。我在IDLE中玩各种事情

convert
,几天前写了一个函数。我忘了自己写的,而且很长一段时间都没有关闭IDLE,所以当我写上面的代码时,我以为
convert
是内置函数。可悲的是没有。

这是我的实现,尽管John Machin的更好一些:

def convert(types, values):    return [t(v) for t, v in zip(types, values)]

用法:

import datetimedef date(s):    return datetime.strptime(s, '%m/%d/%y')>>> convert((int, date, str), ('1', '2/15/09', 'z'))[1, datetime.datetime(2009, 2, 15, 0, 0), 'z']


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/641627.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号