模块的使用
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. 2、Zookeeper端口和ip修改

    clientPort=2181clientPortAddress=192.168.0.120

  2. Anaconda 安装 Python 库(MySQLdb)的方法-(转)

    安装python库的过程中,最重要的地方就是版本需要兼容.其中操作系统为64位,Python为2.X 64位,下载安装文件的时候也要注意版本匹配.其中文件名中包含的cp27表示CPython 2.7版 ...

  3. Redis set数据结构

    set里的数据不能重复 1. 增加set1,值为 a b c d 1 2 3 2. 返回集合元素的数量 3. 重命名set1为set100 4. 查看集合中的成员 5.sdiff set100 set ...

  4. DataFlow编程模型与Spark Structured streaming

    流式(streaming)和批量( batch):流式数据,实际上更准确的说法应该是unbounded data(processing),也就是无边界的连续的数据的处理:对应的批量计算,更准确的说法是 ...

  5. 阅读<Video Timing Controller>笔记

    阅读<Video Timing Controller>笔记   1.Video Timing Controller Block Diagram 2.Example Video Timing ...

  6. ubuntu base make 未找到命令

    引用:https://blog.csdn.net/fenglibing/article/details/7096556 1.先放入UBUNTU安装盘到光盘中: 2.再按顺序执行以下的命令: sudo ...

  7. vue中为对象添加值的问题

    demo: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF ...

  8. phoenix psqlline输入命令无法删除问题解决技巧

    一.引言: phoenix psqlline使用过程中,使用CRT客户端,命令输入后无法删除,想起曾经处理HBaseShell输入后无法删除的解决办法,尝试了一下,居然有效,还是分享给大家把. 二.操 ...

  9. C/C++基础----动态内存

    why 管理较难,忘记释放会内存泄漏,提早释放可能非法引用,重复释放. 为了更容易,更安全的使用动态内存,提供智能指针,其默认初始化保存一个空指针. what shared_ptr允许多个指针指向同一 ...

  10. C#连接Access数据库显示未在本地计算机注册解决方法

    C#连接数据库时会出错 语句如下 string mystr = @"Provider=Microsoft.ACE.OLEDB.12.0; Data Source=C:\Users\hasee ...