python pandas 把数据保存成csv文件,以及读取csv文件获取指定行、指定列数据

本文涉及的产品
视觉智能开放平台,图像资源包5000点
视觉智能开放平台,视频资源包5000点
视觉智能开放平台,分割抠图1万点
简介: 该文档详细介绍了如何使用Python的Pandas库处理图像数据集,并将其保存为CSV文件。示例数据集位于`test_data`目录中,包含5张PNG图片,每张图片名中的数字代表其标签。文档提供了将这些数据转换为CSV格式的具体步骤,包括不同格式的数据输入方法(如NumPy数组、嵌套列表、嵌套元组和字典),以及如何使用`pd.DataFrame`和`to_csv`方法保存数据。此外,还展示了如何读取CSV文件并访问其中的每一行和每一列数据,包括获取列名、指定列数据及行数据的操作方法。

1 数据说明

1、在test_data目录下是我们的数据集(我虚构的,只是为了说明下面的处理过程)

image.png

  • 每张图片名中的数字是样本数据的标签label
  • 这里我们的数据规模大小是5张数据

2、数据保存成csv文件要求

  • 每一行代表一个样本
  • 每一行的第一列表示文件的路径,每一行的第二列表示样本的标签

2 把数据集文件信息使用python pandas保存成csv文件

1、根据上面保存成csv文件的要求,把数据集相关信息保存到csv文件中:

# coding=utf-8
"""
Copyright (c) 2018-2022. All Rights Reserved.

@author: shliang
@email: shliang0603@gmail.com

创建和导入csv文件
"""


import pandas as pd
import glob
import os
import numpy as np

# 创建csv文件
def create_csv_file():
    '''
    把test_data目录下的文件绝对路径保存到csv文件中,同时把文件名中的label也保存下来
    保存两列  filename, label
    :return:
    '''
    img_paths_list = glob.glob("../test_data/*.png")
    labes_list = []
    img_label_list = []
    for path in img_paths_list:
        img_name = os.path.split(path)[-1]
        prefix = os.path.splitext(img_name)[0]
        label = prefix.split('_')[-1]
        labes_list.append(str(label))
        # abspath = os.path.abspath(path)
        img_label_list.append([path, label])


    # 通过zip函数组合每一个样本的path和label: (path, label)
    print(img_paths_list)
    print(labes_list)
    img_label_list2 = list(zip(img_paths_list, labes_list))
    print(img_label_list)
    print(img_label_list2)

    # 保存数据data格式,嵌套列表,每个子列表中表示每一行数据
    # df = pd.DataFrame(data=np.array([[img0, label0],[img1, label1],...,[img4, label4]]),
    #                   columns=['filepath', 'label'])
    df1 = pd.DataFrame(data=img_label_list,
                      columns=['filepath', 'label'])
    df1.to_csv('../test_data/filename1.csv')
    df1.to_csv('../test_data/filename2.csv', index=False)

    # 保存数据data格式,列表中嵌套元组,每个元组中表示每一行数据
    df3 = pd.DataFrame(data=img_label_list2,
                      columns=['filepath', 'label'])
    df3.to_csv('../test_data/filename3.csv')

    # 保存数据data格式,字典格式,key表示列名,value是列表,表示每一列数据
    df4 = pd.DataFrame({
   
   "filename": img_paths_list, "label": labes_list})
    df4.to_csv('../test_data/filename4.csv')

if __name__ == '__main__':
    create_csv_file()

输出结果:

在这里插入图片描述

2、pd.DataFrame(data, columns)的参数

data参数:是输入要保存的数据

该参数的值有几种输入格式,都是可以的:

  • 1)numpy格式data=np.array([[img0, label0],[img1, label1],...,[img4, label4]]
  • 2)列表嵌套列表格式:保存数据data格式,嵌套列表,每个子列表中表示每一行数据:data=[[img0, label0],[img1, label1],...,[img4, label4]]
  • 3)列表嵌套元组格式:保存数据data格式,列表中嵌套元组,每个元组中表示每一行数据:data=[(img0, label0),(img1, label1),...,(img4, label4)]
  • 4)字典格式:保存数据data格式,字典格式,key表示列名,value是列表,表示每一列数据:data={'columns_name1':[img0, img1,...,img4], 'columns_name2': [label0, label1,...,label4]}

columns参数是每一列的列名,值是列名的列表

3、df1.to_csv('../test_data/filename1.csv')的参数,这里只说两个比较常用的参数

  • path_or_buf参数:保存csv文件名
  • index参数:默认值是True,表示保存每行的行索引,如果设置位False表示不保存行索引!

filename1.csv:默认是保存了行索引(filename3.csv和filename4.csv的内容也是如下,一样的!)

image.png

filename2.csv:没有保存行索引

image.png

注意:

我们一般保存的CSV文件是不需要保存索引的,直接设置为False吧,否则这个索引也会作为单独的一列数据

3 使用python pandas 读取csv的每行、每列数据

1、直接上代码,我打印出了每一步的结果,方便大家理解!

# coding=utf-8
"""
Copyright (c) 2018-2022. All Rights Reserved.

@author: shliang
@email: shliang0603@gmail.com

创建和导入csv文件
"""


import pandas as pd
import glob
import os
import numpy as np

# 读取csv文件
def read_csv_file():
    '''
    下面我们来读取数据拿到上面创建的csv文件,主要操作:
    - 读取每一行数据:一行代表一个样本
    - 读取每一列数据:一列表示所有样本的一个属性
    :return:
    '''
    data_info1 = pd.read_csv('../test_data/filename1.csv')
    data_info2 = pd.read_csv('../test_data/filename2.csv')

    print(type(data_info1))  # <class 'pandas.core.frame.DataFrame'>

    # 查看前几行数据
    print(data_info1.head())  # 默认查看前5行数据
    print(data_info1.head(3))  # 指定查看的数据行数
    print(data_info2.head())
    '''
           Unnamed: 0                 filepath  label
    0           0  ../test_data\test_0.png      0
    1           1  ../test_data\test_1.png      1
    2           2  ../test_data\test_2.png      2
    3           3  ../test_data\test_3.png      3
    4           4  ../test_data\test_4.png      4
       Unnamed: 0                 filepath  label
    0           0  ../test_data\test_0.png      0
    1           1  ../test_data\test_1.png      1
    2           2  ../test_data\test_2.png      2
                      filepath  label
    0  ../test_data\test_0.png      0
    1  ../test_data\test_1.png      1
    2  ../test_data\test_2.png      2
    3  ../test_data\test_3.png      3
    4  ../test_data\test_4.png      4
    '''

    # 获取数据的行和列数据
    print(data_info1.shape)  # (5, 3)   # 5行、3列数据,每一行表示一个样本数据,这里的第一列是行索引
    print(data_info2.shape)  # (5, 2)

    # 获取每一列的数据类型
    print(data_info1.dtypes)
    print(data_info2.dtypes)
    '''
    Unnamed: 0     int64
    filepath      object
    label          int64
    dtype: object
    filepath    object
    label        int64
    dtype: object
    '''

    ################################################################################################
    # 获取列名
    columns1 = data_info1.columns
    columns2 = data_info2.columns
    print('coloumns1:', columns1)
    print('coloumns2:', columns2)
    # 把列名转换成列表   to_list() 或 tolist() 两种方法是一样的,源码中有赋值to_list = tolist
    columns1_list = data_info1.columns.tolist()
    columns2_list = data_info2.columns.to_list()
    print('coloumns1 list:', columns1_list)
    print('coloumns2 list:', columns2_list)
    '''
    coloumns1: Index(['Unnamed: 0', 'filepath', 'label'], dtype='object')
    coloumns2: Index(['filepath', 'label'], dtype='object')
    coloumns1 list: ['Unnamed: 0', 'filepath', 'label']
    coloumns2 list: ['filepath', 'label']
    '''

    # 获取指定列数据
    filenames1 = data_info1['filepath']
    filenames2 = data_info1[['filepath']]
    # 获取指定多列数据,把要获取的列名放到一个列表中,确保你的列名正确并存在,否则报KeyError
    filenames3 = data_info1[['filepath', 'label']]
    print('filenames1:', filenames1)
    print('filenames2:', filenames2)
    print('filenames3:', filenames3)
    # 把获取的某一列数转换成列表
    filename1_list = data_info1['filepath'].tolist()
    print('filenames1 list:', filename1_list)
    '''
        filenames1: 0    ../test_data\test_0.png
    1    ../test_data\test_1.png
    2    ../test_data\test_2.png
    3    ../test_data\test_3.png
    4    ../test_data\test_4.png
    Name: filepath, dtype: object
    filenames2:                   filepath
    0  ../test_data\test_0.png
    1  ../test_data\test_1.png
    2  ../test_data\test_2.png
    3  ../test_data\test_3.png
    4  ../test_data\test_4.png
    filenames3:                   filepath  label
    0  ../test_data\test_0.png      0
    1  ../test_data\test_1.png      1
    2  ../test_data\test_2.png      2
    3  ../test_data\test_3.png      3
    4  ../test_data\test_4.png      4
    filenames1 list: ['../test_data\\test_0.png', '../test_data\\test_1.png', '../test_data\\test_2.png', '../test_data\\test_3.png', '../test_data\\test_4.png']
    '''
    ################################################################################################
    # 获取某些行数据

    # 去除指定的某一行数据,索引是从0开始的,如下是取出第3行数据。(如果超过行索引会报KeyError)
    # object 表示字符串类型的值
    line3 = data_info2.loc[2]
    print(line3)
    '''
    filepath    ../test_data\test_2.png
    label                             2
    Name: 2, dtype: object
    '''
    # 取出指定的某一行数据,并转换成列表
    line3_list = data_info2.loc[2].tolist()
    print('line3 list:', line3_list)  # line3 list: ['../test_data\\test_2.png', 2]

    # 取出指定的多行数据,如下取出第2行和第4行数据
    multi_line_data = data_info2.loc[[1, 3]]
    print(multi_line_data)  #  得到的对象是DateFrame,还可以对齐进行行列等操作
    '''
                      filepath  label
    1  ../test_data\test_1.png      1
    3  ../test_data\test_3.png      3
    '''

    # 取出连续多行数据,如下取出第2到第5行数据
    mulut_conti_line_data = data_info2.loc[1:5]
    print(mulut_conti_line_data)   # 得到的对象是DateFrame,还可以对齐进行行列等操作
    '''
                      filepath  label
    1  ../test_data\test_1.png      1
    2  ../test_data\test_2.png      2
    3  ../test_data\test_3.png      3
    4  ../test_data\test_4.png      4
    '''


    # 对DataFrame的每一行进行循环
    for index, row in data_info2.iterrows():
        # print(row)
        '''
        filepath    ../test_data\test_0.png
        label                             0
        Name: 0, dtype: object
        '''

        # 然后根据列名,获取指定的行对应指定列的数据
        filepath = row['filepath']
        label = row['label']
        print(filepath, label)  # ../test_data\test_0.png 0

if __name__ == '__main__':
    read_csv_file()

如果你想了解更多关于pandas的使用技巧可以参考这篇文章

目录
相关文章
|
4天前
|
数据挖掘 PyTorch TensorFlow
|
5天前
|
数据采集 数据挖掘 数据处理
使用Python和Pandas进行数据分析基础
使用Python和Pandas进行数据分析基础
25 5
|
8天前
|
数据可视化 数据挖掘 数据处理
Python中数据可视化的魔法——使用Matplotlib和Pandas
【9月更文挑战第5天】在Python的世界里,数据可视化是连接复杂数据与人类直觉的桥梁。本篇文章将带领读者探索如何使用Matplotlib和Pandas这两个强大的库来揭示数据背后的故事。我们将从基础概念开始,逐步深入到高级技巧,让每一位读者都能轻松创建引人入胜的数据可视化图表,使数据分析变得既直观又有趣。
47 14
|
1天前
|
算法 Python
揭秘!Python数据魔术师如何玩转线性回归,让你的预测精准到不可思议
【9月更文挑战第13天】在数据科学领域,线性回归以其优雅而强大的特性,将复杂的数据关系转化为精准的预测模型。本文将揭秘Python数据魔术师如何利用这一统计方法,实现令人惊叹的预测精度。线性回归假设自变量与因变量间存在线性关系,通过拟合直线或超平面进行预测。Python的scikit-learn库提供了简便的LinearRegression类,使模型构建、训练和预测变得简单直接。
11 5
|
3天前
|
存储 算法 测试技术
预见未来?Python线性回归算法:数据中的秘密预言家
【9月更文挑战第11天】在数据的海洋中,线性回归算法犹如智慧的预言家,助我们揭示未知。本案例通过收集房屋面积、距市中心距离等数据,利用Python的pandas和scikit-learn库构建房价预测模型。经过训练与测试,模型展现出较好的预测能力,均方根误差(RMSE)低,帮助房地产投资者做出更明智决策。尽管现实关系复杂多变,线性回归仍提供了有效工具,引领我们在数据世界中自信前行。
17 5
|
3天前
|
机器学习/深度学习 数据挖掘 TensorFlow
🔍揭秘Python数据分析奥秘,TensorFlow助力解锁数据背后的亿万商机
【9月更文挑战第11天】在信息爆炸的时代,数据如沉睡的宝藏,等待发掘。Python以简洁的语法和丰富的库生态成为数据分析的首选,而TensorFlow则为深度学习赋能,助你洞察数据核心,解锁商机。通过Pandas库,我们可以轻松处理结构化数据,进行统计分析和可视化;TensorFlow则能构建复杂的神经网络模型,捕捉非线性关系,提升预测准确性。两者的结合,让你在商业竞争中脱颖而出,把握市场脉搏,释放数据的无限价值。以下是使用Pandas进行简单数据分析的示例:
17 5
|
3天前
|
存储 安全 算法
RSA在手,安全我有!Python加密解密技术,让你的数据密码坚不可摧
【9月更文挑战第11天】在数字化时代,信息安全至关重要。传统的加密方法已难以应对日益复杂的网络攻击。RSA加密算法凭借其强大的安全性和广泛的应用场景,成为保护敏感数据的首选。本文介绍RSA的基本原理及在Python中的实现方法,并探讨其优势与挑战。通过使用PyCryptodome库,我们展示了RSA加密解密的完整流程,帮助读者理解如何利用RSA为数据提供安全保障。
15 5
|
4天前
|
数据采集 数据挖掘 数据处理
使用Python和Pandas处理CSV数据
使用Python和Pandas处理CSV数据
29 5
|
5天前
|
数据采集 存储 数据挖掘
使用Python读取Excel数据
本文介绍了如何使用Python的`pandas`库读取和操作Excel文件。首先,需要安装`pandas`和`openpyxl`库。接着,通过`read_excel`函数读取Excel数据,并展示了读取特定工作表、查看数据以及计算平均值等操作。此外,还介绍了选择特定列、筛选数据和数据清洗等常用操作。`pandas`是一个强大且易用的工具,适用于日常数据处理工作。
|
6天前
|
安全 数据安全/隐私保护 Python
情书也能加密?Python AES&RSA,让每一份数据都充满爱的密码
【9月更文挑战第8天】在这个数字化时代,情书不再局限于纸笔,也可能以电子形式在网络中传递。为了确保其安全,Python提供了AES和RSA等加密工具,为情书编织爱的密码。首先,通过安装pycryptodome库,我们可以利用AES对称加密算法高效保护数据;接着,使用RSA非对称加密算法加密AES密钥和IV,进一步增强安全性。即使情书被截获,没有正确密钥也无法解读内容。让我们用Python为爱情编织一张安全的网,守护每份珍贵情感。
21 2