《Python编程从入门到实践》记录之Python处理CSV文件数据

目录

1、分析CSV文件(reader()函数、next()函数)

2、打印文件头及其位置

3、提取并读取、显示数据

4、在图表中添加日期(datetime模块)


csv模块包含在Python标准库中,可用于分析CSV文件中的数据行。

1、分析CSV文件(reader()函数、next()函数)

#!/usr/bin/env python
# -*- coding:utf-8 -*-
import csv  # 导入CSV模块
from datetime import datetime

from matplotlib import pyplot as plt

# Get dates, high, and low temperatures from file.
filename = 'sitka_weather_07-2014.csv'
with open(filename) as f:
    reader = csv.reader(f)
    header_row = next(reader)
    print(header_row)

代码解析:

  • csv.reader()函数,创建一个与该文件关联的阅读器对象。
  • CSV模块包含函数next(),返回文件中的下一行,上述代码只调用了一次next(),得到文件的第一行。
  • 将reader返回的数据存储在header_row中,得到与天气相关的文件头,指出每行包括哪些数据

运行结果:

['AKDT', 'Max TemperatureF', 'Mean TemperatureF', 'Min TemperatureF', 'Max Dew PointF', 
'MeanDew PointF', 'Min DewpointF', 'Max Humidity', ' Mean Humidity', ' Min Humidity', 
' Max Sea Level PressureIn', ' Mean Sea Level PressureIn', ' Min Sea Level PressureIn', 
' Max VisibilityMiles', ' Mean VisibilityMiles', ' Min VisibilityMiles', ' Max Wind SpeedMPH', 
' Mean Wind SpeedMPH', ' Max Gust SpeedMPH', 'PrecipitationIn', ' CloudCover', ' Events', ' WindDirDegrees']

2、打印文件头及其位置

为了让文件头数据更容易理解,将列表中的每个头文件及其位置打印出来:

#!/usr/bin/env python
# -*- coding:utf-8 -*-
import csv
from datetime import datetime

from matplotlib import pyplot as plt

# Get dates, high, and low temperatures from file.
filename = 'sitka_weather_07-2014.csv'
with open(filename) as f:
    reader = csv.reader(f)
    header_row = next(reader)

    for index, colum_header in enumerate(header_row):
        print(index, colum_header)

代码解析:

对列表header_row调用了enumerate来获取每个元素的索引及其值

运行结果:

0 AKDT
1 Max TemperatureF
2 Mean TemperatureF
3 Min TemperatureF
4 Max Dew PointF
5 MeanDew PointF
6 Min Dewpoint
<think>嗯,用户想找《Python编程入门实践》的学习资料和教程。之前已经提供过一些资源,比如书籍、在线教程、视频课程和实践平台,现在用户可能希望更详细的信息或者补充。我需要结合用户提供的三个引用内容来完善回答。首先,引用[1]提到了Python之禅的一些原则,比如简洁和可读性,这对新手很重要。应该在回答中强调这些编程哲学,帮助用户理解编写Python代码时的最佳实践。引用[2]详细列出了书籍各章的内容,从安装Python到类、文件处理和测试。这可以用来更具体地介绍这本书的结构,让用户了解每个章节的学习重点,从而规划学习路径。 引用[3]中的例子提到了类型转换和字符串拼接的错误,比如使用str()函数避免类型错误。这可以作为常见问题解决的示例,帮助用户注意类似错误,并给出代码示例。用户可能还需要知道如何有效利用这些资源,比如分阶段学习,结合理论和项目实践。同时,可能需要推荐一些额外的资源,如官方文档或社区支持,来补充书籍内容。还要检查用户是否可能有其他需求,比如寻找中文社区的支持或实战项目建议。需要确保回答结构清晰,分点列出资源,并附上代码示例和相关问题。最后,根据系统指令,正确使用LaTeX格式,并在引用处标注来源。</think>### Python编程入门实践学习资料与教程指南 #### 一、核心学习框架(基于《Python编程:从入门实践》结构) 1. **基础语法与工具** - 安装Python并运行第一个程序(如`print("Hello world!")`),掌握开发环境配置[^2] - 变量与数据类型:字符串、整数、浮点数,注意类型转换(如`str(age)`避免`TypeError`[^3]) - 使用交互式终端快速验证代码片段,例如验证`import this`输出的Python之禅原则[^1] 2. **数据结构与逻辑控制** - 列表操作:存储多个元素并实现遍历(如`for number in numbers:`[^1]) - 字典关联数据:键值对管理复杂信息(如用户信息存储)[^2] - 条件语句与循环:`if-else`逻辑判断和`while`循环控制[^2] 3. **进阶编程能力** - 函数封装:定义可复用的代码块(如计算阶乘函数) - 面向对象编程:通过类模拟现实对象(如`Dog`类包含属性和方法)[^2] - 文件与异常处理:读写文件(如`.txt`或`.csv`)并使用`try-except`捕获错误[^2] #### 二、关键学习资源推荐 | 资源类型 | 推荐内容 | 特点 | |----------------|-----------------------------------------------------------------------------------|----------------------------------------------------------------------| | **书籍** | 《Python编程:从入门实践》 | 包含基础语法+3个实战项目(游戏、数据可视化、Web应用)[^2][^3] | | **在线文档** | [Python官方文档](https://docs.python.org/zh-cn/3/) | 权威语法参考,含标准库详解 | | **实战平台** | [LeetCode](https://leetcode.com/)(算法练习) | 通过题目巩固基础逻辑(如列表去重、字符串处理) | | **社区支持** | [Stack Overflow](https://stackoverflow.com/) | 解决编码问题的全球开发者社区 | #### 三、典型代码示例 1. **类型转换与字符串拼接** ```python age = 23 # 正确方式:使用str()转换数字类型 print("Happy " + str(age) + "rd Birthday!") # 输出: Happy 23rd Birthday![^3] ``` 2. **列表遍历与条件判断** ```python numbers = [1, 2, 3, 4, 5] even_numbers = [num for num in numbers if num % 2 == 0] # 列表推导式筛选偶数 ``` #### 四、学习策略建议 1. **分阶段实践** - 初级阶段:每天完成书中的章节练习(如第2章变量操作、第3章列表) - 中级阶段:复现书中项目(如外星人入侵游戏)并尝试扩展功能 - 高级阶段:参与开源项目或构建个人作品集(如数据分析脚本) 2. **调试技巧** - 使用`print()`输出中间变量值 - 利用PyCharm的调试工具设置断点 - 阅读错误提示(如`SyntaxError: unterminated string literal`提示字符串引号未闭合[^3])
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值