【pandas基础】–数据读取

数据读取是第一步,只有成功加载数据之后,后续的操作才有可能。

pandas可以读取和导入各种数据格式的数据,如CSV,Excel,JSON,SQL,HTML等,不需要手动编写复杂的读取代码。

1. 各类数据源

pandas提供了导入各类常用文件格式数据的接口,这里介绍3种最常用的加载数据的接口。

1.1 从 CSV 文件读取数据

读取csv文件的接口:read_csv()

import pandas as pd

# 此csv中包含一些中国人口的统计信息
df = pd.read_csv("/path/to/china-population.csv")

df.head() # 显示前5条数据

image.png

1.2 从 excel 文件读取数据

读取excel文件的接口:read_excel ()
读取excel文件时,默认读取第一个sheet中的数据。

import pandas as pd

# 此excel中的数据与上面csv文件中的一样
df = pd.read_excel("/path/to/china-population.xlsx")

df.head() # 显示前5条数据

image.png

1.3 从网络中读取数据

除了从本地文件中读取数据之外,read_csvread_excel也可以直接从URL读取数据。
比如,上面的csv文件和excel文件可以从下面的地址下载。
http://databook.top:8888/pandas/china-population.csv
http://databook.top:8888/pandas/china-population.xlsx

可以直接将URL传给 read_csvread_excel,不用下载保存本地。

import pandas as pd

df = pd.read_csv("http://databook.top:8888/pandas/china-population.csv")
df_excel = pd.read_excel("http://databook.top:8888/pandas/china-population.xlsx")

2. 不同分隔符

csv 文件中默认用逗号,分隔不同的字段,不过,也有很多csv文件不用逗号分隔,用其他生僻的符号来分隔。

import pandas as pd

df = pd.read_csv("http://databook.top:8888/pandas/china-population-sep.csv")
df.head()

image.png
文件china-population-sep.csv|来分隔不同的字段,直接读取的话,变成只有一个字段。

这时,要明确设置分隔符。

import pandas as pd

df = pd.read_csv("http://databook.top:8888/pandas/china-population-sep.csv", sep="|")
df.head()

image.png
这样就得到了正确的数据结构。

3. 设置列名称

除了可以设置分隔符之外,读取数据时,也可以设置列的名称。
上面的例子中,列的名称都是字母的缩写,读取文件时可以替换成中文名称。

import pandas as pd

df = pd.read_csv(
    "http://databook.top:8888/pandas/china-population-sep.csv",
    sep="|",
    names=["年份数字", "年份", "指标编码", "指标名称", "人口数"],
)
df.head()

image.png

通过names参数设置列的名称,names参数是个列表,其中元素的个数一般与列的数目保持一致。
如果names中元素个数少于列的数目,那么多出来的列会作为索引(关于索引index,后续会详细介绍)。

import pandas as pd

df = pd.read_csv(
    "http://databook.top:8888/pandas/china-population-sep.csv",
    sep="|",
    names=["指标编码", "指标名称", "人口数"],
)
df.head()

image.png

如果 names中元素个数多于列的数目,多出来的元素作为新增的空白列。

import pandas as pd

df = pd.read_csv(
    "http://databook.top:8888/pandas/china-population-sep.csv",
    sep="|",
    names=["年份数字", "年份", "指标编码", "指标名称", "人口数", "列名称", "列名称2"],
)
df.head()

image.png

上面的例子中,我们应该发现了一个问题,设置 names作为新的列名称之后,原有的列名称被当成了实际的数据。
也就是:
image.png

设置新的列名称时,如果数据中包含列名称的话,需要忽略掉这个名称。
设置 header=0,忽略作为标题的第一行。
如果文件本来就没有标题的话,设置 header=None

import pandas as pd

df = pd.read_csv(
    "http://databook.top:8888/pandas/china-population-sep.csv",
    sep="|",
    header=0,
    names=["年份数字", "年份", "指标编码", "指标名称", "人口数"],
)
df.head()

image.png

4. 随机生成数据

pandas支持从很多数据源读取数据,不过,有时候我们只想尝试尝试 pandas中的一些方法,并不想创建数据源。

这时,可以通过 numpy包创建一个随机的二维矩阵,直接将这个二维矩阵的数据导入 pandas即可。
下面的例子创建了一个10行3列的数据集。

import pandas as pd
import numpy as np

data = np.random.rand(10,3)
df = pd.DataFrame(data, columns=["data1", "data2", "data3"])
df.head()

image.png

通过临时创建的随机数据,可以尝试 pandas提供的各类接口。

5. 总结回顾

本篇了主要介绍了数据的读取方法,重点介绍的是 csv 文件的读取方式,因为这是最常用的数据源。
其他数据源的读取方式也大同小异,各种数据源的差异会体现在不同接口的参数上。

本文所用到的数据:

  1. http://databook.top:8888/pandas/china-population.csv
  2. http://databook.top:8888/pandas/china-population-sep.csv
  3. http://databook.top:8888/pandas/china-population.xlsx

本文关联的微信视频号短视频:
pandas01-数据读取.png

原文链接:https://www.cnblogs.com/wang_yb/p/17371731.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:【pandas基础】–数据读取 - Python技术站

(0)
上一篇 2023年5月4日
下一篇 2023年5月4日

相关文章

  • 基于Python和TFIDF实现提取文本中的关键词

    下面我将为您详细讲解基于Python和TFIDF实现提取文本中的关键词的完整攻略: 一、什么是TFIDF TFIDF(Term Frequency-Inverse Document Frequency)是一种常用的文本信息处理技术,用于评估一段文本中某个词语对于整篇文本的重要程度。 TF(Term Frequency)指的是某个词语在文本中出现的频率,TF越…

    python 2023年6月3日
    00
  • Python实现队列的方法

    Python实现队列的方法可以使用Python内置的列表(list)来实现。队列的特点是先进先出(FIFO),我们可以使用列表的append()方法来实现数据的入队操作,使用pop(0)方法来实现数据的出队操作,下面是实现队列的代码示例: class Queue: def __init__(self): self.items = [] def enqueue…

    python 2023年5月19日
    00
  • Python之parser.add_argument解读

    Python中的argparse模块是用于解析命令行参数和选项的标准模块。add_argument方法是argparse.ArgumentParser类中的一个方法,用于向该类中添加命令行选项和参数。 1. add_argument方法的基本用法 add_argument方法的基本用法如下: parser.add_argument(‘name’, actio…

    python 2023年6月3日
    00
  • Python创建二维数组与初始化的实践举例

    关于“Python创建二维数组与初始化的实践举例”的攻略,可以分成以下几个步骤: 1. 定义一个二维数组 一个二维数组通常由多个一维数组组成。那么在Python中,其实可以通过以下两种方式定义一个二维数组: 方式一 使用列表生成式嵌套列表生成式,如下所示: a = [[0 for i in range(m)] for j in range(n)] 这里的a就…

    python 2023年6月5日
    00
  • wxPython实现绘图小例子

    下面是“wxPython实现绘图小例子”的完整攻略: 简介 wxPython是一款使用Python语言编写的GUI框架,能够帮助开发者快速搭建交互式的图形界面程序。本文将介绍如何使用wxPython实现一个绘图小例子,通过该例子,我们能够更好的了解wxPython的使用。 准备工作 在开始编写代码前,需要先安装wxPython库。可以使用pip安装,命令如下…

    python 2023年5月19日
    00
  • Python机器学习之Kmeans基础算法

    以下是关于“Python机器学习之Kmeans基础算法”的完整攻略: 简介 Kmeans是一种常见的聚类算法,它可以将数据集分成多个簇。Python中有多种库可以实现Kmeans算法,例如scikit-learn和numpy。本教程将介绍如何使用Python实现Kmeans基础算法,并提供两个示例。 Kmeans算法 Kmeans算法是一种迭代算法,它将数据…

    python 2023年5月14日
    00
  • python字符串和常用数据结构知识总结

    Python字符串和常用数据结构知识总结 字符串 在Python中,字符串是不可变的序列,即表示一系列字符的有序集合。字符串可以通过单引号或双引号来表示,例如: str1 = ‘Hello World!’ str2 = "Python is awesome." 常见字符串操作 字符串支持多种操作,以下是一些常见的操作: 字符串连接 使用+…

    python 2023年5月13日
    00
  • 关于python 跨域处理方式详解

    关于Python跨域处理方式详解 跨域是指在浏览器中,一个网页的脚本试图访问另一个网页的脚本时,由于浏览器的同源策略,会出现跨域问题。Python作为一种常用的后端语言,也需要处理跨域问题。本文将详细讲解Python跨域处理的方式。 什么是跨域 在浏览器中,同源策略是一种安全机制,它限制了一个网页的脚本只能访问同源的资源。同源是指协议、域名、端口号都相同。如…

    python 2023年5月15日
    00
合作推广
合作推广
分享本页
返回顶部