模块的使用
01 模块的循环导入问题
 解决方案一: 把循环导入的语句放到名字定义的后面
 解决方案二: 将循环导入语句放到函数内(先定义确定名称空间)
02 区分python文件的两种用途
 #当文件被执行时__name__=='__main__'
 #当文件被导入时__name__=='模块名'
 # if __name__ == '__main__':    (输入main时可直接出现左边语句) 
 #     f1()
03 模块的搜索路径
 # 模块搜索路径的优先级
  # 1. 内存中已经加载过的
  # 2. 内置模块
  # 3. sys.path #  第一个值是当前执行文件所在的文件夹
 添加路径方式:1 sys.path.append(r'需要添加的模块路径')  (sys.path本质是一个储存有路径的列表)
     2 from dir1.dir2 import m2  (在执行文件同级下寻找dir1,再在dir1下寻找dir2,再在dir2下寻找m2导入)
 注意:模块名绝对不能和内置模块或第三方模块同名
 环境变量是以当前执行文件为准的
  # 强调:所有被导入的模块参照环境变量sys.path都是以执行文件为准的
  方式2中:在一个模块中导入另一个模块,也是以执行文件的环境变量(sys.path)为准的
04 绝对导入与相对导入
 绝对导入: 以执行文件的sys.path为起始点开始导入,称之为绝对导入
         优点: 执行文件与被导入的模块中都可以使用
         缺点: 所有导入都是以sys.path为起始点,导入麻烦
 相对导入: 参照当前所在文件的文件夹为起始开始查找,称之为相对导入
         符号: .代表当前所在文件的文件加,..代表上一级文件夹,...代表上一级的上一级文件夹
         优点: 导入更加简单
         缺点: 只能在被导入的模块中使用,不能在执行文件中用
 注意:执行文件中只能用绝对导入
05 软件开发的目录规范
 ATM (程序存放的总文件,也是项目的名字,所有相关文件军存放在这里)
  bin  (程序开始文件存放地点,就是执行文件的所在地)   
   start.py    (执行文件的文件名,可以有start.py2,和start.py同级)
  conf (存放程序中相关参数的文件的地点,所有相关参数的文件都放在这里)
   settings.py (存放参数的文件,但参数有很多种的时候,可以是多个)
  core (主体核心程序的存放地点,最重要的部分)
   src.py      (主体核心程序,需要是可以有多个)
  db   (需要永久保存数据的地点)
   userinfo.txt(存放用户信息的文件,也可以有存放商品信息的文件等多个文件)
  lib  (存放自定义常用模块的地点)
   common.py   (自定义常用的模块1,可以有多个2,3,4,....)
  log  (存放日志文件的地方)
   transaction.log (日志文件,用于存放交易记录,可以是多个)
  Readme(解释程序功能和每个文件作用的文件,方便用户的使用和查看)

day16(软件开发目录规范)的更多相关文章

  1. Python记录13:软件开发目录规范

    软件开发目录规范 开发一个软件,一个工程项目,一般应该具备以下的几个基本的文件夹和模块,当然,这并不是一成不变的,根据项目的不同会有一定的差异,不过作为一个入门级的新手,建议暂时按照以下的规范编写: ...

  2. Python 浅谈编程规范和软件开发目录规范的重要性

    最近参加了一个比赛,然后看到队友编程的代码,我觉得真的是觉得注释和命名规范的重要性了,因为几乎每个字符都要咨询他,用老师的话来说,这就是命名不规范的后续反应.所以此时的我意识到写一篇关于注释程序的重要 ...

  3. python 之 软件开发目录规范 、logging模块

    6.4 软件开发目录规范 软件(例如:ATM)目录应该包含: 文件名 存放 备注 bin start.py,用于起动程序   core src.py,程序核心功能代码   conf settings. ...

  4. Python模块:Re模块、附软件开发目录规范

    Re模块:(正则表达式) 正则表达式就是字符串的匹配规则 正则表达式在多数编程语言里都有相应的支持,Python里面对应的模块时re 常用的表达式规则:(都需要记住) “ . ”   #  默认匹配除 ...

  5. python模块导入-软件开发目录规范-01

    模块 模块的基本概念 模块: # 一系列功能的结合体 模块的三种来源 """ 模块的三种来源 1.python解释器内置的模块(os.sys....) 2.第三方的别人写 ...

  6. py 包和模块,软件开发目录规范

    目录 py 包和模块,软件开发目录规范 什么是包? 什么是模块? 软件开发目录规范 py 包和模块,软件开发目录规范 什么是包? 包指的是内部包__init__.py的文件夹 包的作用: 存放模块,包 ...

  7. python基础语法10 函数递归,模块,软件开发目录规范

    函数递归: 函数递归指的是重复 “直接调用或间接调用” 函数本身, 这是一种函数嵌套调用的表现形式. 直接调用: 指的是在函数内置,直接调用函数本身. 间接调用: 两个函数之间相互调用间接造成递归. ...

  8. python浅谈编程规范和软件开发目录规范的重要性

    前言 我们这些初学者,目前要做的就是遵守代码规范,这是最基本的,而且每个团队的规范可能还不一样,以后工作了,尽可能和团队保持一致,目前初学者就按照官方的要求即可 新人进入一个企业,不会接触到核心的架构 ...

  9. day21 模块与包+软件开发目录规范

    目录 一.导入模块的两种方式 二.模块搜索的路径的优先级 三.循环导入 四.区分py文件的两种用途 五.编写一个规范的模板 五.包 1 什么是包 2 为什么要有包 3 包的相关使用 3.1 在当前文件 ...

随机推荐

  1. pycharm开发django项目 static报404解决方法

    settings文件中确保有以下配置 # Static files (CSS, JavaScript, Images)# https://docs.djangoproject.com/en/1.10/ ...

  2. Redis 键命令

    1.设置key值 set name zhangsan 删除key del name 2. 判断key是否存在 exists a,返回1 说明存在:  0 表示不存在 3. 剩余过期时间 ttl 返回- ...

  3. Hanlp等七种优秀的开源中文分词库推荐

    Hanlp等七种优秀的开源中文分词库推荐 中文分词是中文文本处理的基础步骤,也是中文人机自然语言交互的基础模块.由于中文句子中没有词的界限,因此在进行中文自然语言处理时,通常需要先进行分词. 纵观整个 ...

  4. hadoop发行版本之间的区别

    Hadoop是一个能够对大量数据进行分布式处理的软件框架. Hadoop 以一种可靠.高效.可伸缩的方式进行数据处理.Hadoop的发行版除了有Apache hadoop外cloudera,horto ...

  5. Spring Cloud(Dalston.SR5)--Ribbon 中间层负载均衡

    Spring Cloud 集成了 Ribbon 并结合 Eureka 可以实现客户端的负载均衡,使用 @LoadBalanced 修饰的 RestTemplate 类拥有了负载均衡功能,在 Sprin ...

  6. 批处理手动设置电脑的ip

    参考: http://blog.csdn.net/jiangzhanchang/article/details/7063152 http://wenda.haosou.com/q/1378697364 ...

  7. 进程池pool

    如果有多个进程,同一时间只能有限个给cpu运行 from multiprocessing import Process,Pool import time,os def bar(arg): print( ...

  8. sofa-rpc 服务端源码流程走读

    sofa-rpc是阿里开源的一款高性能的rpc框架,这篇文章主要是对sofa-rpc provider启动服务流程的一个代码走读,下面是我简单绘制的一个基本的关系流程图 下面我们根据sofa-rpc代 ...

  9. 通过U盘启动vmware虚拟机

    不能通过虚拟机的USB功能,而是通过硬盘映射功能实现,操作方法如下图. 1.添加硬盘,注意接口类型与启动系统的支持(XPPE不支持scsi,但10pe支持) 2.硬盘类型 3.选择U盘映射 4.按F2 ...

  10. CAD求交点函数

    public void IntersectWith( Entity entityPointer, Intersect intersectType, Point3dCollection points, ...