处理任意格式的文本文件
admin
2023-07-24 09:22:46
0
# 内存--硬盘内容  序列话
# 手动挡
# f = open('文件名或类似文件的东西', '文件打卡模式')
# f是文件对象或指针,用来进行读写操作
# f.close()

# 三种模式:
# w. write 写
# r read 读
# a append  追加内容
import os 
%pwd
'C:\\study\\jupyter'
f = open('coop.txt', 'w')  # 用w的方式打开文件,不存在则创建
f.write('coop' * 7)  # 向文件写入字符串
f.close()
with open('coop-1.txt', 'w') as f:
    f.write('coop' * 7)
with open('coop.txt') as f: # 文件名后面的r是默认模式
    data = f.read()# 读出所有内容,保存到一个变量
    print(data)
coopcoopcoopcoopcoopcoopcoop
# 在打开文件时要考虑此文件是否存在,使用try except
with open('coop.txt', 'a') as f:
    f.write('coop1\n')
    f.write('coop2\n')
    f.write('\n111')
    f.write('\n222')
with open('coop.txt') as f:  
    print(f.readline())  # 每次读一行
    print(f.readline())
    print(f.readline())
    print(f.readline())
coopcoopcoopcoopcoopcoopcoopcoop

coop

coop1

coop2
with open('coop.txt') as f:  # 当文件不是很大时用readlines
    print(f.readlines())   # 如何去掉\n
['coopcoopcoopcoopcoopcoopcoopcoop\n', 'coop\n', 'coop1\n', 'coop2\n', '\n', '111\n', '222']
with open('coop.txt') as f:  
    print(f.tell())  # tell()告诉我们光标现在的位置(列的位置)
    print(f.readline())  # 每次读一行
    print(f.tell())
    print(f.readline())
    print(f.tell())
    print(f.seek(0))  # seek(0)让光标返回到初始0的位置
    print(f.readline())
    print(f.readline())
    f.seek(5)

    print(f.readline())
    print(f.tell())
0
coopcoopcoopcoopcoopcoopcoopcoop

34
coop

40
0
coopcoopcoopcoopcoopcoopcoopcoop

coop

oopcoopcoopcoopcoopcoopcoop

34
f = open('coop.txt', 'a')
f.write('append\n')
# print(f.readlines())
7
with open('coop.txt',) as f:
    data = f.read()
    print(data)
coopcoopcoopcoopcoopcoopcoopcoop
coop
coop1
coop2

111
222appendappendappendappendappendappendappend
append
append
append
append
append
##############
# 匹配相应后缀名的文件
import fnmatch
for f in os.listdir('.'):
    if fnmatch.fnmatch(f, '*.txt'):
        print(f)
    elif fnmatch.fnmatch(f, '*.pdf)'):
        print('find pdf', f)
coop-1.txt
coop.txt
# 匹配相应后缀名的文件
import fnmatch
for f in os.listdir('.'):
    if fnmatch.fnmatch(f, '?+.txt'):  # 正则?,一个字符
        print(f)
    elif fnmatch.fnmatch(f, '?.pdf)'):
        print('find pdf', f)
#################
import fnmatch
for f in os.listdir('.'):
    if fnmatch.fnmatch(f, '\w+.txt'):  # 正则?,一个字符
        print(f)
    elif fnmatch.fnmatch(f, '?.pdf)'):
        print('find pdf', f)
# 单纯匹配某种命名规则的文件
import glob
for f in glob.glob('[0-9].txt'):
    print(f)
0.txt
1.txt
import glob
for f in glob.glob('[0-9]+.txt'):  # 不可以加+号,已匹配更多字符
    print(f)
############################
# 序列化 picle ,持久化, 存盘
# 后缀名随意,推荐使用pkl
# 存储python的数据结构
name_list = ['coop', 'fang', 'beijing']
data = {'name':name_list, 'age':(2,3,4)}
import pickle
with open('data.pkl', 'wb') as f: # 使用wb,通用二进制存储
    pickle.dump(data, f)
with open('data.pkl', 'rb') as f:
    data = pickle.load(f)
    print(data)
{'name': ['coop', 'fang', 'beijing'], 'age': (2, 3, 4)}
############################
# 虚拟文件,临时文件,不需要真的存到磁盘
import io
output = io.StringIO()
output.write('the first code\n')
print('ddd', file=output)

# 去除内容
contents = output.getvalue()
print(contents)

#关闭文件,清理缓存
output.close()   # 打印顺序为什么是那个样子
the first code
ddd
# 用类似字典的方式存储任意的python对象  pickle存储的是数据结构
import shelve
with shelve.open('coop.she') as so:
    so['coop'] = 'fang'  # 生成三个文件
with shelve.open('coop.she') as so:
    print(so['coop'])
fang

相关内容

热门资讯

2026年万元预算分屏体验好的... 对于追求高效办公和沉浸娱乐的用户来说,折叠屏手机的大屏分屏功能无疑是核心吸引力。当预算来到万元级别,...
从种子到餐桌,海垦如何链通世界... 一滴乳胶,“链”上研发,摇身一变成为凉爽轻柔的凉被;新品种黑米,“链”通加工,成为花青素满满的美味粽...
高市早苗亲信被曝出差时多次叫情... 【环球网报道】据日本朝日电视台6月26日报道,日本政府当天发布消息称,日本内阁官房长官首席秘书官茂木...
5G-A出新机制 高峰期网速分... 6月26日消息,广东移动联合华为在深圳完成全国首个用户级5G-A动态切片全流程测试,这套技术已经打通...
李在明称担忧中国渔船“非法捕捞... 澎湃新闻记者 杨文钦 谢瑞强6月26日,外交部发言人郭嘉昆主持例行记者会。韩联社记者提问,近期韩国总...
委内瑞拉代总统发文感谢特朗普和... 当地时间6月24日晚,委内瑞拉接连发生两次7级以上强烈地震,损失惨重。特朗普政府及时向委内瑞拉伸出援...
厦门:“一人公司”有了“娘家人... 过去需要一个团队完成的工作,如今一个人、一台电脑、几款AI工具便能高效运转。这是人工智能时代催生的新...
AI狂飙,审美力 反而成了“新... ■ 向勇 最近,AI教父杰弗里·辛顿针对超级智能的公开警示,揭示了人工智能迭代已远超人类预期,逐步具...
豆包开始收68元,谁会掏钱? 6月24日,豆包把一块价格牌挂了出来。 标准套餐,连续包月68元。加强套餐,连续包月200元。高级套...
多家水果电商称遭同一男子网图骗... 近日,抖音平台多家水果电商老板发布视频,称遭遇安徽淮北一男子通过骗赔的方式,不断“白嫖”高端品质榴莲...