模块的使用
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. 配置B类内网 和 配置A类内网

    首先 A 类网 对应的 子网掩码是255.0.0.0 B 类网 对应的 子网掩码是255.255.0.0 C 类网 对应的 子网掩码是255.255.255.0 一般来说 10 开头的都是 A 类网  ...

  2. tensorflow学习笔记

    常量的四则运算 import tensorflow as tf data1 = tf.constant(2) data2 = tf.constant(10) dataAdd=tf.add(data1, ...

  3. PCA原理解释(二)

    PCA在做数据处理,一般会有一个数据预处理,其中一个目标就是将取数据特征向相关性. 为什么要去特征的相关性? 因为数据如果有相关性,在学习的时候是冗余的,徒增学习成本:所以对于数据处理(也称之为白化, ...

  4. struts中的dojo控件sx:submit布局问题

    想在一个四列的表格中插入两个按钮,希望实现下面的布局效果: 其中保存按钮为<sx:submit />控件.按照下面的代码布局: <tr><td align="c ...

  5. ASP.NET AJAX入门系列(5):使用UpdatePanel控件(二) UpdatePanel

    UpdatePanel可以用来创建丰富的局部更新Web应用程序,它是ASP.NET 2.0 AJAX Extensions中很重要的一个控件,其强大之处在于不用编写任何客户端脚本,只要在一个页面上添加 ...

  6. Spring Cloud(Dalston.SR5)--Hystrix 断路器-缓存

    在 Spring Cloud 中可以使用注解的方式来支持 Hystrix 的缓存,缓存与合并请求功能需要先初始化请求上下文才能实现,因此,必须实现 javax.servlet.Filter 用于创建和 ...

  7. mongodb morphia删除数组中指定条件的数据

    先看mongodb操作: db.test.update({"msgid":170},{"$pull":{"msg":{"comti ...

  8. SDI工程时钟路径分析

    SDI工程时钟路径分析 //------------- Receive Ports - RX Fabric Output Control Ports ------------- output rxou ...

  9. 阅读OReilly.Web.Scraping.with.Python.2015.6笔记---BeautifulSoup---findAll

    阅读OReilly.Web.Scraping.with.Python.2015.6笔记---BeautifulSoup---findAll 1..BeautifulSoup库的使用 Beautiful ...

  10. Maya中输出nuke脚本的方法

    因项目需要,三维部门跟踪组动画组都需要一个能够快速输出nuke预合成工程的脚本.脚本已经写完,源码不便于放出来,写一个大致思路吧. 我首先分析了nuke工程,内部包含了哪些节点,这些节点有哪些属性需要 ...