json序列化

将系统的某个状态保存为字符串(挂起),序列化。

import json

json.dumps():序列化

json.loads():反序列化

简单类型数据处理

import pickle

pickle.dumps()

pickle.loads()

可以处理所有类型,二进制数据,需要rb,wb方式读取写入文件

pickle.dump(object,file)

file.close()

pickle.load(file)

file.close()

只能dump一次,如果有多个状态,要存在多个文件中

软件目录结构规范

软件目录,首字母大写

执行文件包、主包(软件名命名)、测试包、文档目录、配置文件包,安装文件,依赖关系文件,README

readme内容要求

相对路径与绝对路径

通过设置路径调用主包中的main.py

ATM作业

从bin入口看代码,找到主类,查看类的方法,

注释写在方法声明的正下方,多行注释

使用装饰器验证登录状态,而不是让用户登录

写日志封装成函数

封装用户登录,解耦

根据数据库不同的登录验证方式,实现同一种登录方式

类似janggo的数据库连接配置,支持多数据库

一个用户一个json文件,满足多用户同时登录需求,防止写脏数据

使用字典取消if判断

Python模块详解

定义

模块本质就是py结尾的python文件,用来从逻辑上组织python代码(变量、函数、类、逻辑:实现一个功能)

包是一个目录,带有一个__init__.py文件,用来从逻辑上组织模块,导入包实际是解释执行__init__.py,在__init__.py中import包中的模块(需要from . import module),在其他代码文件中import package,就可以直接调用模块的相关功能了。

使用方法

import 模块1,模块2…

模块.属性

模块.方法

from 模块 import *,从模块导入所有代码

from 模块 import 特定方法 as 别名

from 模块 import m1,m2,m3…

import本质

import module:定义一个变量module,将导入的模块(py文件)解释(运行)了一遍,把结果传给(赋值)module

form module import m1:

路径搜索和搜索路径

当前路径搜索,或者sys.path中的路径

将目录加入sys.path列表中,就可以进行搜索

os.path.abspath(__file__):获取当前文件的路径,__file__当前文件

os.path.dirname():获取目录名

导入优化

sys.path.insert(path):将路径插入第一个位置

如果在代码中多处调用模块中的方法,可以采用直接导入方法的方式优化,防止每次都去导入路径查找

Python学习笔记十:json序列化,软件结构目录规范,ATM作业讲解,import本质论的更多相关文章

  1. Python学习笔记(十二)—Python3中pip包管理工具的安装【转】

    本文转载自:https://blog.csdn.net/sinat_14849739/article/details/79101529 版权声明:本文为博主原创文章,未经博主允许不得转载. https ...

  2. Python学习笔记:json模块和pickle模块(数据序列化)

    Python中的json模块和pickle都是用于数据的序列化和反序列化,它们提供的方法也是一样的:dumps,dump,loads,load dumps(obj):将对象序列化为str. dump( ...

  3. python学习笔记十六:读取JSON文件

    读取JSON文件可以用JSON库,示例代码: #coding:utf-8 import json with open("msg.json") as jsonfile: json_d ...

  4. Python学习日记(十八) 序列化模块

    什么是序列? 就是每一个元素被有序的排成一列 什么是序列化? 就是将原本的列表.字典等内容转化成字符串的过程 什么时候会用到序列化? 数据存储(把数据放在文件.数据库),网络传输等 序列化的目的 1. ...

  5. Python学习笔记十_模块、第三方模块安装、模块导入

    一.模块.包 1.模块 模块实质上就是一个python文件.它是用来组织代码的,意思就是把python代码写到里面,文件名就是模块的名称,test.py test就是模块的名称 2.包 包,packa ...

  6. python学习笔记:json与字典的转换(dump 和dumps load和loads的区别)

    1. json序列化(字典转成字符串)方法: dumps:无文件操作            dump:序列化+写入文件 2. json反序列化(字符串转成字典)方法: loads:无文件操作     ...

  7. python 学习笔记十六 django深入学习一 路由系统,模板,admin,数据库操作

    django 请求流程图 django 路由系统 在django中我们可以通过定义urls,让不同的url路由到不同的处理函数 from . import views urlpatterns = [ ...

  8. python学习笔记(十六)-Python多线程多进程

    一.线程&进程 对于操作系统来说,一个任务就是一个进程(Process),比如打开一个浏览器就是启动一个浏览器进程,打开一个记事本就启动了一个记事本进程,打开两个记事本就启动了两个记事本进程, ...

  9. python 学习笔记(十二) 文件和序列化

    python 文件读写和序列化学习.## python文件读写`1 打开并且读取文件` f = open('openfile.txt','r') print(f.read()) f.close() ` ...

随机推荐

  1. linux 下MySQL的安装

    一.安装MySQL   1.下载源码包     从mysql官网上下载linux下的source包mysql-5.0.51b.tar.gz,注意是下载GNU tar格式的,不是rpm包.    2.解 ...

  2. 前端构建之--gulp

    gulp相关插件: 1.del / gulp-clean 删除文件,用于清空文件 2.browser-sync 用于自动刷新浏览器 3.gulp-htmlmin 用于压缩html 4.gulp-cle ...

  3. meta标签的使用(转)

    1.Expires(期限) 说明:可以用于设定网页的到期时间.一旦网页过期,必须到服务器上重新传输. 用法: <meta http-equiv="expires" conte ...

  4. 关于Struts2通配符无效的说明

    在struts2.3之前的版本,正常的配置就可以了,但在struts2.3版本之后,使用通配符调用方法时,内部会验证是否允许访问该方法. 1.struts2.5 为了增加安全性,在 struts.xm ...

  5. CADisplayLink分析

    1.固定频率定时器: 2.UI帧率性能检测: 3.cpu动画控制器:

  6. 【模板】Dijkstra总结

    Dijkstra算法使用于跑最短路的算法. 算法思想 假定图是不带负权的有向图或无向图,采用贪心策略,每次扩展一个距离为最短的点,在以这个点为中间点,更新其他的所有点的距离.当所有边权都为正时,由于不 ...

  7. 巧用DNSlog实现无回显注入

    测试一些网站的时候,一些注入都是无回显的,我们可以写脚本来进行盲注,但有些网站会ban掉我们的ip,这样我们可以通过设置ip代理池解决, 但是盲注往往效率很低,所以产生了DNSlog注入.具体原理如下 ...

  8. 4、Android-数据存储方案(SQLite数据库存储)

    4.4.SQLite数据库存储 这是Android内置的数据库 是一款轻量级的关系型数据库 运算速度非常快.占用资源少.通常只需要几百kb的内存就够了 因而特别适合在移动端设备上使用 SQLite不仅 ...

  9. Asp.Net Core + Ocelot 网关搭建:负载均衡的配置

    前言   上一篇中简单做了一个网关Demo.本篇中也记录一下负载均衡的配置实现. 演示   首先开三个服务,端口分别为 60001,60003,60005,然后分别启动三个服务.接下来在ApiGate ...

  10. concatenate函数

    numpy.concatenate((a1, a2, ...), axis=0) Join a sequence of arrays along an existing axis.(按轴axis连接a ...