Python操作csv文件


最近实验要对数据进行操作,获得的数据基本都是以文本的形式存储到csv文件中,所以这里记录一下处理的过程,方便下次使用。

读写操作

使用csv操作

import csv

读取csv文件

def read_csv(file_path):
    """
    读取csv文件并以列表形式输出
    :param file_path: str
    :return: [list[str]]
    """
    res = []
    with open(file_path, 'r',encoding='utf-8')as f:
        read = csv.reader(f)
        for line in read:
            res.append(line)
    return res

在这里插入图片描述


def read_csv_complex(file_path, index=0):
    """
    读取复杂csv文件并以列表形式输出
    :param index: int    前几行是字符串
    :param file_path: str
    :return: [list[list..]]
    """
    person_msg = []
    with open(file_path, 'r', encoding='utf-8')as f:
        read = csv.reader(f)
        for lines in read:
            res = lines[:index]
            for line in lines[index:]:
                if line:
                    res.append(eval(line))
            person_msg.append(res)
    return person_msg

将列表写入csv文件


def write_csv(res, write_path, _type='w'):
    """
    处理数据,并写入新的文件
    :param res: [list[str]]
    :param write_path: str
    :param _type : str   (默认是覆盖写w,添加的话可以改成a)
    :return: bool
    """
    if not res:
        return False
    try:
        with open(write_path, _type, newline='', encoding='utf-8') as csvfile:  # 1. 创建文件对象
            writer = csv.writer(csvfile)  # 2. 基于文件对象构建 csv写入对象
            if type(res[0]) == list:
                for line in res:
                    writer.writerow(line)  # 3. 写入csv文件内容
            else:
                writer.writerow(res)  # 3. 写入csv文件内容
        return True
    except IOError:
        return False


删除某一行或一列(使用pandas)

import pandas as pd
file_path = '../dataset/titanic/w_train.csv'
write_path = '../dataset/titanic/w_test.csv'
# 读取文件数据
data = pd.read_csv(file_path)

data_new = data.drop(["Name"], axis=1)  # 删除表头为Name的这列数据  ,axis=1表示列, axis=0表示删除行,默认值为0
# 或者使用 data.drop([data.columns[index]], axis=1)  # 删除Name这列数据

# 写入文件
data_new.to_csv(write_path, index=0)

将这个使用方法封装了一下

def del_col_row_csv(file_path, write_path=None, index=None, axis=0):
    """
    删除行或者列
    :param file_path:  str 读入文件地址
    :param write_path: str  输出文件地址
    :param index: str/int   删除行或者列的索引(删除列时可以是字符串或者序号,删除行时必须时序号)
    删除行时,不算title,序号从0开始
    删除列时,序号直接从0开始
    :param axis: int    axis=1 是列, axis=0 是行
    :return:DataFrame   删除后的结果
    """
    try:
        if index is None:
            return False
        data = pd.read_csv(file_path)
        if axis == 0:
            if type(index) != str:
                title = index
            else:
                title = data.columns[index]
        else:
            if type(index) == str:
                title = index
            else:
                title = data.columns[index]
        data_new = data.drop([title], axis=axis)  # 删除表头为Name的这列数据 ,axis=1表示列, axis=0表示删除行,默认值为0
        if write_path is not None:
            data_new.to_csv(write_path, index=0)
        return True
    except IOError:
        return False
  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

南方-D

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值