广告位联系
返回顶部
分享到

python关于文件加载及处理方式

python 来源:互联网 作者:佚名 发布时间:2022-09-28 17:20:21 人浏览
摘要

关于文件加载及处理 1、检查python 关于文件加载及处理方式文件路径是否存在,如果不存在就创建此路径。 1 2 3 #如果不存在路径,就创建一个这样的路径 if not os.path.exists(exp_path): os.

关于文件加载及处理

1、检查python

关于文件加载及处理方式文件路径是否存在,如果不存在就创建此路径。

1

2

3

#如果不存在路径,就创建一个这样的路径

    if not os.path.exists(exp_path):

        os.mkdir(exp_path)

  • os.path.exists():判断括号里的文件是否存在的意思,括号内的可以是文件路径.如果存在就返回True,不存在返回False
  • os.mkdir():创建路径

2、对文件夹下面的文件名称进行列表排列

1

file_list = os.listdir(dir_path)

3、过滤不符合要求的文件

filter() 函数用于过滤序列,过滤掉不符合条件的元素,返回由符合条件元素组成的新列表

1

filter(function, iterable)

  • function -- 判断函数。
  • iterable -- 可迭代对象

1

2

3

4

5

def is_odd(n):

    return n % 2 == 1

  

newlist = filter(is_odd, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10])

print(newlist)

1

[1, 3, 5, 7, 9]

4、用于将元组转换为列表

  • list()

^(* ̄(oo) ̄)^

元组与列表是非常类似的,区别在于元组的元素值不能修改。

元组是放在括号中,列表是放于方括号中

5、打开文件codeces,open()

查阅资料后和实验后,发现和open()的功能差不多,但在进行爬虫或者其他方式得到数据写入文件时会有编码不统一的问题,所以就一般都统一转换为Unicode编码。

总之,用codeces,open()更便捷点。

6、readlines()

每次按行读取整个文件内容,将读取到的内容放到一个列表中,返回list类型

7、strip()

每次按行读取整个文件内容,将读取到的内容放到一个列表中,返回list类型 

python文件处理(总结)

1、txt文件

1.1 txt文件读取

1

2

3

4

        with open("11.txt", 'r') as file:

            for l in file:

                idnos.append(l.replace('\n',''))

        f.close()  # 关闭文件,这个可以是个好习惯哦

1.2 txt写入 不覆盖写入

1

2

3

4

            with open("d.txt", 'a',encoding='utf-8') as file:

                file.write('\n' + '摘要:' + gaiyao)

                file.write('\n')

            file.close()

1.3 各个文件标签的含义 

访问模式 说明
r 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。
w 打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
a 打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
rb 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。
wb 以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
ab 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
r+ 打开一个文件用于读写。文件指针将会放在文件的开头。
w+ 打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
a+ 打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
rb+ 以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。
wb+ 以二进制格式打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
ab+ 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。

1.4 逐行读取txt中所有内容 

1

2

3

4

5

6

7

8

9

#coding=utf-8

f = open('11.txt', 'r')

content = f.readlines()

print(type(content))

i=1

for temp in content:

    print("%d:%s" % (i, temp))

    i += 1

f.close()

1.5 读取txt中 前两行的内容 

1

2

3

4

5

6

7

#coding=utf-8

f = open('11.txt', 'r')

content = f.readline()

print("1:%s" % content)

content = f.readline()

print("2:%s" % content)

f.close()

1.6 文件拷贝

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

# 提示输入文件

oldFileName = input("请输入要拷贝的文件名字:")

# 以读的方式打开文件

oldFile = open(oldFileName,'rb')

# 提取文件的后缀

fileFlagNum = oldFileName.rfind('.')

if fileFlagNum > 0:

    fileFlag = oldFileName[fileFlagNum:]

# 组织新的文件名字

newFileName = oldFileName[:fileFlagNum] + '[复件]' + fileFlag

# 创建新文件

newFile = open(newFileName, 'wb')

# 把旧文件中的数据,一行一行的进行复制到新文件中

for lineContent in oldFile.readlines():

    newFile.write(lineContent)

# 关闭文件

oldFile.close()

newFile.close()

1.7 文件的相关操作

文件重命名

1

2

import os

os.rename("毕业论文.txt", "毕业论文-最终版.txt")

删除文件

1

2

import os

os.remove("毕业论文.txt")

创建文件夹

1

2

import os

os.mkdir("张三")

获取当前目录

1

2

import os

os.getcwd()

改变默认目录

1

2

import os

os.chdir("../")

获取目录列表

1

2

import os

os.listdir("./")

删除文件夹

1

2

import os

os.rmdir("张三")

1.8 文件管理 - 学生管理系统

注:先创建一个文件:info_data.data

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

import time

import os

# 定一个列表,用来存储所有的学生信息(每个学生是一个字典)

info_list = []

def print_menu():

    print("---------------------------")

    print("      学生管理系统 V1.0")

    print(" 1:添加学生")

    print(" 2:删除学生")

    print(" 3:修改学生")

    print(" 4:查询学生")

    print(" 5:显示所有学生")

    print(" 6:保存数据")

    print(" 7:退出系统")

    print("---------------------------")

def add_new_info():

    """添加学生信息"""

    global info_list

    new_name = input("请输入姓名:")

    new_tel = input("请输入手机号:")

    new_qq = input("请输入QQ:")

    for temp_info in info_list:

        if temp_info['name'] == new_name:

            print("此用户名已经被占用,请重新输入")

            return  # 如果一个函数只有return就相当于让函数结束,没有返回值

    # 定义一个字典,用来存储用户的学生信息(这是一个字典)

    info = {}

    # 向字典中添加数据

    info["name"] = new_name

    info["tel"] = new_tel

    info["qq"] = new_qq

    # 向列表中添加这个字典

    info_list.append(info)

def del_info():

    """删除学生信息"""

    global info_list

    del_num = int(input("请输入要删除的序号:"))

    if 0 <= del_num < len(info_list):

        del_flag = input("你确定要删除么?yes or no")

        if del_flag == "yes":

            del info_list[del_num]

    else:

        print("输入序号有误,请重新输入")

def modify_info():

    """修改学生信息"""

    global info_list

    modify_num = int(input("请输入要修改的序号:"))

    if 0 <= modify_num < len(info_list):

        print("你要修改的信息是:")

        print("name:%s, tel:%s, QQ:%s" % (info_list[modify_num]['name'],

            info_list[modify_num]['tel'],info_list[modify_num]['qq']))

        info_list[modify_num]['name'] = input("请输入新的姓名:")

        info_list[modify_num]['tel'] = input("请输入新的手机号:")

        info_list[modify_num]['qq'] = input("请输入新QQ:")

    else:

        print("输入序号有误,请重新输入")

def search_info():

    """查询学生信息"""

    search_name = input("请输入要查询的学生姓名:")

    for temp_info in info_list:

        if temp_info['name'] == search_name:

            print("查询到的信息如下:")

            print("name:%s, tel:%s, QQ:%s" % (temp_info['name'],

                temp_info['tel'], temp_info['qq']))

            break

    else:

        print("没有您要找的信息....")

def print_all_info():

    """遍历学生信息"""

    print("序号\t姓名\t\t手机号\t\tQQ")

    i = 0

    for temp in info_list:

        # temp是一个字典

        print("%d\t%s\t\t%s\t\t%s" % (i, temp['name'], temp['tel'], temp['qq']))

        i += 1

def save_data():

    """加载之前存储的数据"""

    f = open("info_data.data", "w")

    f.write(str(info_list))

    f.close()

def load_data():

    """加载之前存储的数据"""

    global info_list

    f = open("info_data.data")

    content = f.read()

    info_list = eval(content)

    f.close()

def main():

    """用来控制整个流程"""

    # 加载数据(1次即可)

    load_data()

    while True:

        # 1. 打印功能

        print_menu()

        # 2. 获取用户的选择

        num = input("请输入要进行的操作(数字):")

        # 3. 根据用户选择,做相应的事情

        if num == "1":

            # 添加学生

            add_new_info()

        elif num == "2":

            # 删除学生

            del_info()

        elif num == "3":

            # 修改学生

            modify_info()

        elif num == "4":

            # 查询学生

            search_info()

        elif num == "5":

            # 遍历所有的信息

            print_all_info()

        elif num == "6":

            # 保存数据到文件中

            save_data()

        elif num == "7":

            # 退出系统

            exit_flag = input("亲,你确定要退出么?~~~~(>_<)~~~~(yes or no) ")

            if exit_flag == "yes":

                break

        else:

            print("输入有误,请重新输入......")

        input("\n\n\n按回车键继续....")

        os.system("clear")  # 调用Linux命令clear完成清屏

# 程序的开始

main()

2、csv文件操作

2.1 csv写入

1

2

3

4

with open('新1.csv', 'a', encoding='utf-8-sig', newline='') as f:

    csv_writer = csv.writer(f, delimiter=',')

    csv_writer.writerow(

        [str(name), str(zijin), str(guimo), str(jingli), str(phone1), str(phone2),str(chanpin)])


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 : https://blog.csdn.net/weixin_42187536/article/details/123788465
相关文章
  • Python Django教程之实现新闻应用程序

    Python Django教程之实现新闻应用程序
    Django是一个用Python编写的高级框架,它允许我们创建服务器端Web应用程序。在本文中,我们将了解如何使用Django创建新闻应用程序。 我们将
  • 书写Python代码的一种更优雅方式(推荐!)

    书写Python代码的一种更优雅方式(推荐!)
    一些比较熟悉pandas的读者朋友应该经常会使用query()、eval()、pipe()、assign()等pandas的常用方法,书写可读性很高的「链式」数据分析处理代码
  • Python灰度变换中伽马变换分析实现

    Python灰度变换中伽马变换分析实现
    1. 介绍 伽马变换主要目的是对比度拉伸,将图像灰度较低的部分进行修正 伽马变换针对的是对单个像素点的变换,也就是点对点的映射 形
  • 使用OpenCV实现迷宫解密的全过程

    使用OpenCV实现迷宫解密的全过程
    一、你能自己走出迷宫吗? 如下图所示,可以看到是一张较为复杂的迷宫图,相信也有人尝试过自己一点一点的找出口,但我们肉眼来解谜
  • Python中的数据精度问题的介绍

    Python中的数据精度问题的介绍
    一、python运算时精度问题 1.运行时精度问题 在Python中(其他语言中也存在这个问题,这是计算机采用二进制导致的),有时候由于二进制和
  • Python随机值生成的常用方法

    Python随机值生成的常用方法
    一、随机整数 1.包含上下限:[a, b] 1 2 3 4 import random #1、随机整数:包含上下限:[a, b] for i in range(10): print(random.randint(0,5),end= | ) 查看运行结
  • Python字典高级用法深入分析讲解
    一、 collections 中 defaultdict 的使用 1.字典的键映射多个值 将下面的列表转成字典 l = [(a,2),(b,3),(a,1),(b,4),(a,3),(a,1),(b,3)] 一个字典就是一个键对
  • Python浅析多态与鸭子类型使用实例
    什么多态:同一事物有多种形态 为何要有多态=》多态会带来什么样的特性,多态性 多态性指的是可以在不考虑对象具体类型的情况下而直
  • Python字典高级用法深入分析介绍
    一、 collections 中 defaultdict 的使用 1.字典的键映射多个值 将下面的列表转成字典 l = [(a,2),(b,3),(a,1),(b,4),(a,3),(a,1),(b,3)] 一个字典就是一个键对
  • Python淘宝或京东等秒杀抢购脚本实现(秒杀脚本

    Python淘宝或京东等秒杀抢购脚本实现(秒杀脚本
    我们的目标是秒杀淘宝或京东等的订单,这里面有几个关键点,首先需要登录淘宝或京东,其次你需要准备好订单,最后要在指定时间快速
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计