博客
关于我
22 模块原则
阅读量:646 次
发布时间:2019-03-14

本文共 1065 字,大约阅读时间需要 3 分钟。

原则:

  • 每个模块在被导入时,必须保证其所有代码可以顺利执行。
  • 在导入文件时,所有未缩进的代码都会被执行。
  • 示例:

    模块1:p1

    def func():    print("哈哈哈")    print("ooooo")

    导入:

    import p1print("*" * 10)

    结果:

    ooooo**********

    再看第二个示例:

    模块1:p1

    def func():    print("哈哈哈")    print("ooooo")    func()

    导入:

    import p1print("*" * 10)

    运行结果:

    ooooo哈哈哈**********

    问题:

    在实际开发中,主程序如何避免在被导入时执行?

    解决方法:

    使用__name__魔法方法。

    __name__特性:

  • 当文件用于测试程序时,__name__始终为'__main__'(字符串)。
  • 当文件作为模块导入时,__name__为文件名。
  • 示例:

    模块1:p1

    def run():    print("哈哈")    print(__name__)    run()

    导入:

    import p1print("*" * 10)

    运行结果:

    p1哈哈**********

    这样可以看到,导入时__name__的值变为文件名p1

    问题解决:

    如何让测试程序在被导入时不被执行?

    解决方法:

    使用条件判断。

    示例:

    文件名:p2

    def func():    a = "小猫"    b = "小狗"    return f"{a}在某个不经意的时刻便爱上了{s}" % (a, b)def func1():    a = "男人"    b = "女人"    return f"{a} 的责任就是让 {b} 放心{s}" % (a, b)

    导入:

    import p2print("*" * 10)

    结果:

    **********

    再看另一种导入方式:

    import p2print(p2.func())print(p2.func1())print("*" * 10)

    结果:

    小猫在某个不经意的时刻便爱上了小狗男人 的责任就是让 女人 放心**********

    理解了吗?

    模块标准语法:

    def func():    passdef func():    passdef func():    passdef func():    passdef main():    passif __name__ == "__main__":    main()

    转载地址:http://tdsoz.baihongyu.com/

    你可能感兴趣的文章
    mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
    查看>>
    mysql中json_extract的使用方法
    查看>>
    mysql中json_extract的使用方法
    查看>>
    mysql中kill掉所有锁表的进程
    查看>>
    mysql中like % %模糊查询
    查看>>
    MySql中mvcc学习记录
    查看>>
    mysql中null和空字符串的区别与问题!
    查看>>
    MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
    查看>>
    MYSQL中TINYINT的取值范围
    查看>>
    MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
    查看>>
    Mysql中varchar类型数字排序不对踩坑记录
    查看>>
    MySQL中一条SQL语句到底是如何执行的呢?
    查看>>
    MySQL中你必须知道的10件事,1.5万字!
    查看>>
    MySQL中使用IN()查询到底走不走索引?
    查看>>
    Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
    查看>>
    MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
    查看>>
    mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
    查看>>
    mysql中出现Unit mysql.service could not be found 的解决方法
    查看>>
    mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
    查看>>
    Mysql中各类锁的机制图文详细解析(全)
    查看>>