免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 8480 | 回复: 9
打印 上一主题 下一主题

python读写csv文件的问题 [复制链接]

论坛徽章:
2
2015年迎新春徽章
日期:2015-03-04 10:01:44程序设计版块每日发帖之星
日期:2015-06-28 22:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-06-23 21:23 |只看该作者 |倒序浏览
如何实现读写csv文件的某一行数据,另外如何统计csv文件中有多少行和多少列

论坛徽章:
13
双鱼座
日期:2013-10-23 09:30:05数据库技术版块每日发帖之星
日期:2016-04-20 06:20:00程序设计版块每日发帖之星
日期:2016-03-09 06:20:002015亚冠之塔什干火车头
日期:2015-11-02 10:07:452015亚冠之德黑兰石油
日期:2015-08-30 10:07:07数据库技术版块每日发帖之星
日期:2015-08-28 06:20:00数据库技术版块每日发帖之星
日期:2015-08-05 06:20:002015年迎新春徽章
日期:2015-03-04 09:57:09辰龙
日期:2014-12-03 14:45:52酉鸡
日期:2014-07-23 09:46:23亥猪
日期:2014-03-13 08:46:22金牛座
日期:2014-02-11 09:36:21
2 [报告]
发表于 2015-06-24 10:41 |只看该作者
fileio搞起啊,结合"str" in line 就好了

论坛徽章:
14
15-16赛季CBA联赛之辽宁
日期:2019-06-16 15:47:3515-16赛季CBA联赛之广夏
日期:2016-08-13 21:24:352015亚冠之武里南联
日期:2015-07-07 17:37:372015亚冠之萨济拖拉机
日期:2015-07-06 17:07:482015亚冠之全北现代
日期:2015-06-04 13:54:272015亚冠之城南
日期:2015-05-21 15:43:212015年亚洲杯之伊朗
日期:2015-04-25 18:20:362015年亚洲杯之伊朗
日期:2015-04-20 16:06:052015年亚洲杯之科威特
日期:2015-03-07 12:51:26丑牛
日期:2014-12-30 10:26:38申猴
日期:2014-09-28 22:40:18金牛座
日期:2014-09-13 21:12:22
3 [报告]
发表于 2015-06-24 11:03 |只看该作者
@reyleon  是这位大神的菜~

论坛徽章:
60
20周年集字徽章-20	
日期:2020-10-28 14:04:3015-16赛季CBA联赛之北京
日期:2016-07-06 15:42:0715-16赛季CBA联赛之同曦
日期:2016-06-12 10:38:0915-16赛季CBA联赛之佛山
日期:2016-05-27 11:54:56黄金圣斗士
日期:2015-12-02 11:44:35白银圣斗士
日期:2015-11-25 14:32:43白银圣斗士
日期:2015-11-23 12:53:352015亚冠之布里斯班狮吼
日期:2015-10-21 16:55:482015亚冠之首尔
日期:2015-09-01 16:46:052015亚冠之德黑兰石油
日期:2015-08-31 11:39:192015亚冠之萨济拖拉机
日期:2015-08-28 21:06:5315-16赛季CBA联赛之广东
日期:2016-07-12 14:58:53
4 [报告]
发表于 2015-06-24 11:07 |只看该作者
reb00t 发表于 2015-06-24 11:03
@reyleon  是这位大神的菜~


论坛徽章:
2
2015年迎新春徽章
日期:2015-03-04 10:01:44程序设计版块每日发帖之星
日期:2015-06-28 22:20:00
5 [报告]
发表于 2015-06-24 12:33 |只看该作者
回复 2# bikong0411

具体解释下呢,这个怎么用

另外不太理解delimiter=’:’, quoting=csv.QUOTE_NONE 这2个参数是干嘛的
   

论坛徽章:
26
2015亚冠之胡齐斯坦钢铁
日期:2015-06-25 21:40:202015亚冠之柏斯波利斯
日期:2015-08-31 17:03:192015亚冠之柏斯波利斯
日期:2015-11-07 13:10:00程序设计版块每日发帖之星
日期:2015-11-10 06:20:00每日论坛发贴之星
日期:2015-11-10 06:20:00程序设计版块每日发帖之星
日期:2015-11-26 06:20:00程序设计版块每日发帖之星
日期:2015-12-02 06:20:00黄金圣斗士
日期:2015-12-07 17:57:4615-16赛季CBA联赛之天津
日期:2015-12-23 18:34:14程序设计版块每日发帖之星
日期:2016-01-02 06:20:00程序设计版块每日发帖之星
日期:2016-01-06 06:20:00每日论坛发贴之星
日期:2016-01-06 06:20:00
6 [报告]
发表于 2015-06-24 15:03 |只看该作者
先别急
看看书
学习 学习 这个
open
close
sum
enumerate
for
+
+=
list comprehension
print

书可以很好的解决你的疑问

http://bbs.chinaunix.net/thread-1825165-1-1.html

这就是它的一个很好的价值所在
看看书对你学习Python有很大帮助

搞本学习手册看看吧

论坛徽章:
4
白羊座
日期:2013-11-05 10:26:09冥斗士
日期:2015-11-17 14:19:55白银圣斗士
日期:2015-11-17 15:13:0815-16赛季CBA联赛之新疆
日期:2016-04-01 09:10:58
7 [报告]
发表于 2015-06-25 09:07 |只看该作者
回复 1# maple412
得到csv文件的行列数:
  1. def detect_csv_header(filename):
  2.     handler = open(filename, "r")
  3.     content = handler.readlines()
  4.     handler.close()

  5.     return csv.Sniffer().has_header("".join(content))

  6. def get_csv_row_col(filename):
  7.     row = 0
  8.     has_header = detect_csv_header(filename)
  9.     datareader = csv.reader(open(filename), dialect='excel')
  10.     for line in datareader:
  11.         if datareader.line_num == 1:
  12.             col = len(line)
  13.             if not has_header:
  14.                 row = row + 1
  15.         else:
  16.             row = row + 1
  17.     return row, col
复制代码
只要修改下get_csv_row_col,就可以读取指定行了。

论坛徽章:
2
2015年迎新春徽章
日期:2015-03-04 10:01:44程序设计版块每日发帖之星
日期:2015-06-28 22:20:00
8 [报告]
发表于 2015-06-26 11:18 |只看该作者
回复 7# icymirror

如果想要在某一行或者某一列写数据,该如何操作呢

   

论坛徽章:
4
白羊座
日期:2013-11-05 10:26:09冥斗士
日期:2015-11-17 14:19:55白银圣斗士
日期:2015-11-17 15:13:0815-16赛季CBA联赛之新疆
日期:2016-04-01 09:10:58
9 [报告]
发表于 2015-06-26 16:41 |只看该作者
回复 8# maple412
那就要一边读原来的文件,一边写到新文件了。
当读到需要修改的地方,把你的内容直接放到新文件里面,然后,继续读原来的文件剩下的部分,写到新文件里面去。

论坛徽章:
32
处女座
日期:2013-11-20 23:41:20双子座
日期:2014-06-11 17:20:43戌狗
日期:2014-06-16 11:05:00处女座
日期:2014-07-22 17:30:47狮子座
日期:2014-07-28 15:38:17金牛座
日期:2014-08-05 16:34:01亥猪
日期:2014-08-18 13:34:25白羊座
日期:2014-09-02 15:03:55金牛座
日期:2014-11-10 10:23:58处女座
日期:2014-12-02 09:17:52程序设计版块每日发帖之星
日期:2015-06-16 22:20:002015亚冠之塔什干火车头
日期:2015-06-20 23:28:22
10 [报告]
发表于 2015-06-26 18:10 |只看该作者
本帖最后由 yestreenstars 于 2015-06-26 18:10 编辑

假设分隔符为制表符,可以参考以下代码:
  1. with open('1.txt') as f:
  2.     lines = f.readlines()
  3.     field = lines[0].split('\t')
  4.     print 'row: %d\ncolumn: %d' % (len(field), len(lines))
复制代码

评分

参与人数 1信誉积分 +10 收起 理由
substr函数 + 10 很给力!给力!

查看全部评分

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP