关于内存的占用和思路的拓展

本文探讨了一种有效的文件内容分页显示方法,通过读取文件并按页展示内容,避免了大量数据一次性加载造成的资源浪费。文章对比了两种实现方式,一种是将所有内容加载到内存中再进行分页,另一种是按需读取,仅在内存中保留当前页数据,后者更节省内存。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

遇到一个问题,题目是这样的:

随意写一个20行以上的文件
运行程序,先将内容读到内存中,
接收用户输入页码,每页5条,仅输出当页的内容

先贴出我的代码:
def func(page):  #在函数中输入页码
    lis = []     
    dic = {}
    with open('03name',encoding='utf-8') as f:
        for i in f:
            lis.append(i.strip())   #把文件中的每一行读取出来,去掉前后空格及换行符,放入列表

        count = 0
        while count < len(lis)/5 +1:  #给出一个循环,限制条件是整数的页码+1
            #这样不管最后一页有没有内容都放入字典中
            dic.setdefault(count + 1,lis[0+count*5:5+count*5]) #切片把每一页的内容都放入字典
            count += 1
        return dic[page]

print(func(6))

再给出答案的代码:

with open('03name',encoding='utf-8') as f:
    l = f.readlines()  #直接读每行内容放进列表
page_input = int(input('输入您要查找的页码:'))
page,mod = divmod(len(l),5)  #除余来获取文件内容的整数页和剩余几行内容
if mod:
    page += 1  #有余数则页码+1
if page_input > page or page_input < 0:  
    print('输入错误')
elif page_input == page and mod != 0:  #如果输入的是最后一页并且有余数
    for i in range(mod):                     
        print(l[(page_input - 1) * 5 + i])#那么打印列表中的剩余行
else:
    for i in range(5):  
        print(l[(page_input - 1)*5 + i])#这样取值,而不用切片不占用内存

很明显,答案表给出了另一种思路,并且这种思路只在内存中存储存放了一个包含文件内容的列,节省了空间

转载于:https://www.cnblogs.com/RyanJin/p/8244771.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值