python模块之sys模块和序列化模块

下面小编就为大家带来一篇python模块之sys模块和序列化模块(实例讲解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

sys模块

sys模块是与python解释器交互的一个接口

sys.argv   命令行参数List,第一个元素是程序本身路径sys.exit(n)  退出程序,正常退出时exit(0),错误退出sys.exit(1)sys.version  获取Python解释程序的版本信息sys.path   返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值sys.platform  返回操作系统平台名称

登录后复制

序列化模块

序列化的目的:

立即学习“Python免费学习笔记(深入)”;

以某种存储形式使自定义对象持久化

将对象从一个地方传递到另一个地方

使程序更具维护性

序列化结构

json

# Json模块提供了四个功能:dumps、dump、loads、loadimport jsondic = {'k1':'v1','k2':'v2','k3':'v3'}str_dic = json.dumps(dic) #序列化:将一个字典转换成一个字符串print(type(str_dic),str_dic) # {"k3": "v3", "k1": "v1", "k2": "v2"}#注意,json转换完的字符串类型的字典中的字符串是由""表示的dic2 = json.loads(str_dic) #反序列化:将一个字符串格式的字典转换成一个字典#注意,要用json的loads功能处理的字符串类型的字典中的字符串必须由""表示print(type(dic2),dic2) # {'k1': 'v1', 'k2': 'v2', 'k3': 'v3'}list_dic = [1,['a','b','c'],3,{'k1':'v1','k2':'v2'}]str_dic = json.dumps(list_dic) #也可以处理嵌套的数据类型 print(type(str_dic),str_dic) # [1, ["a", "b", "c"], 3, {"k1": "v1", "k2": "v2"}]list_dic2 = json.loads(str_dic)print(type(list_dic2),list_dic2) # [1, ['a', 'b', 'c'], 3, {'k1': 'v1', 'k2': 'v2'}]

登录后复制

import jsonf = open('json_file','w')dic = {'k1':'v1','k2':'v2','k3':'v3'}json.dump(dic,f) #dump方法接收一个文件句柄,直接将字典转换成json字符串写入文件f.close()f = open('json_file')dic2 = json.load(f) #load方法接收一个文件句柄,直接将文件中的json字符串转换成数据结构返回f.close()print(type(dic2),dic2)

登录后复制

import jsonf = open('file','w')json.dump({'国籍':'中国'},f)ret = json.dumps({'国籍':'中国'})f.write(ret+'')json.dump({'国籍':'美国'},f,ensure_ascii=False)ret = json.dumps({'国籍':'美国'},ensure_ascii=False)f.write(ret+'')f.close()ensure_ascii关键字参数

登录后复制

pickle

json & pickle

json,用于字符串 和 python数据类型间进行转换

pickle,用于python特有的类型 和 python的数据类型间进行转换

# pickle模块提供了四个功能:dumps、dump(序列化,存)、loads(反序列化,读)、load (不仅可以序列化字典,列表...可以把python中任意的数据类型序列化import pickledic = {'k1':'v1','k2':'v2','k3':'v3'}str_dic = pickle.dumps(dic)print(str_dic) #一串二进制内容dic2 = pickle.loads(str_dic)print(dic2) #字典import timestruct_time = time.localtime(1000000000)print(struct_time)f = open('pickle_file','wb')pickle.dump(struct_time,f)f.close()f = open('pickle_file','rb')struct_time2 = pickle.load(f)print(struct_time2.tm_year)

登录后复制

shelve

# shelve也是python提供给我们的序列化工具,比pickle用起来更简单一些。# shelve只提供给我们一个open方法,是用key来访问的,使用起来和字典类似。import shelvef = shelve.open('shelve_file')f['key'] = {'int':10, 'float':9.5, 'string':'Sample data'} #直接对文件句柄操作,就可以存入数据f.close()import shelvef1 = shelve.open('shelve_file')existing = f1['key'] #取出数据的时候也只需要直接用key获取即可,但是如果key不存在会报错f1.close()print(existing)

登录后复制

# 这个模块有个限制,它不支持多个应用同一时间往同一个DB进行写操作。所以当我们知道我们的应用如果只进行读操作,我们可以让shelve通过只读方式打开DBimport shelvef = shelve.open('shelve_file', flag='r')existing = f['key']f.close()print(existing)

登录后复制

# 由于shelve在默认情况下是不会记录待持久化对象的任何修改的,所以我们在shelve.open()时候需要修改默认参数,否则对象的修改不会保存。import shelvef1 = shelve.open('shelve_file')print(f1['key'])f1['key']['new_value'] = 'this was not here before'f1.close()f2 = shelve.open('shelve_file', writeback=True)print(f2['key'])f2['key']['new_value'] = 'this was not here before'f2.close()"""writeback方式有优点也有缺点。优点是减少了我们出错的概率,并且让对象的持久化对用户更加的透明了;但这种方式并不是所有的情况下都需要,首先,使用writeback以后,shelf在open()的时候会增加额外的内存消耗,并且当DB在close()的时候会将缓存中的每一个对象都写入到DB,这也会带来额外的等待时间。因为shelve没有办法知道缓存中哪些对象修改了,哪些对象没有修改,因此所有的对象都会被写入。"""

登录后复制

以上就是python模块之sys模块和序列化模块的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2266437.html

(0)
上一篇 2025年2月27日 09:20:48
下一篇 2025年2月26日 00:28:10

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • python模块之time模块介绍

    下面小编就为大家带来一篇python模块之time模块(实例讲解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧 time 表示时间的三种形式 时间戳(timestamp) :通常来说,时间戳表示的是从197…

    2025年2月27日
    200
  • python difflib模块详解

    这篇文章主要为大家详细介绍了python difflib模块的示例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 difflib模块提供的类和方法用来进行序列的差异化比较,它能够比对文件并生成差异结果文本或者html格式的差异化比较页面…

    2025年2月27日
    200
  • Python套接字编程

    这篇文章主要为大家详细介绍了python网络编程的相关资料,python套接字编程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 Python 提供了两个级别访问的网络服务。 低级别的网络服务支持基本的 Socket,它提供了标准的 B…

    2025年2月27日
    200
  • python点对点简单实现

    这篇文章主要为大家详细介绍了python实现简单点对点p2p聊天,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 点对点聊天首先是基于多线程的网络编程,其次就是将每一个连接都保存为一个具有独一属性的对象并添加到连接列表中,对于每一个连接对…

    2025年2月27日 编程技术
    200
  • Python三级菜单实例详解

    下面小编就为大家带来一篇python三级菜单的实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧 要求: 打印省、市、县三级菜单 可返回上一级 可随时退出程序 立即学习“Python免费学习笔记(深入)”; …

    编程技术 2025年2月27日
    200
  • 如何选择Python代码的编辑器

    下面小编就为大家带来一篇基于python代码编辑器的选用(详解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧 Python开发环境配置好了,但发现自带的代码编辑器貌似用着有点不大习惯啊,所以咱们就找一个“好…

    2025年2月27日
    200
  • Python中descriptor的详细介绍

    本文给大家分python 中的 descriptor相关知识,非常不错,具有参考借鉴价值,需要的朋友参考下吧 定义 通常,一个 descriptor 是具有“绑定行为”的对象属性。所绑定行为可通过 descriptor 协议被自定义的 __…

    编程技术 2025年2月27日
    200
  • Python实现有用户和商家入口的购物商城

    下面小编就为大家带来一篇python 实现购物商城,含有用户入口和商家入口的示例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧 这是模拟淘宝的一个简易的购物商城程序。 用户入口具有以下功能: 登录认证 可以锁…

    编程技术 2025年2月27日
    200
  • python中reload用法实例

    与from和import相比,reload是内置函数,而不是语句,下面这篇文章主要给大家介绍了关于python中reload(module)用法的相关资料,文中给出了详细的示例代码供大家参考学习,需要的朋友们下面来一起看看吧。 前言 本文主…

    编程技术 2025年2月27日
    200
  • linux怎么关闭进程中的命令_linux要如何关闭进程中的命令

    可在 Linux 中关闭进程的方法有:1)使用“kill”命令,指定进程 ID;2)使用“pkill”命令,指定进程名称或模式;3)使用“killall”命令,指定进程名称或模式;4)使用“Ctrl + C”组合键。 如何在 Linux 中…

    2025年2月27日
    200

发表回复

登录后才能评论