博客
关于我
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 [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
    查看>>
    MySQL _ MySQL常用操作
    查看>>
    MySQL – 导出数据成csv
    查看>>
    MySQL —— 在CentOS9下安装MySQL
    查看>>
    mysql 不区分大小写
    查看>>
    mysql 两列互转
    查看>>
    MySQL 中开启二进制日志(Binlog)
    查看>>
    MySQL 中文问题
    查看>>
    MySQL 中日志的面试题总结
    查看>>
    MySQL 中随机抽样:order by rand limit 的替代方案
    查看>>
    MySQL 为什么需要两阶段提交?
    查看>>
    mysql 为某个字段的值加前缀、去掉前缀
    查看>>
    mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
    查看>>
    mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
    查看>>
    mysql 主键重复则覆盖_数据库主键不能重复
    查看>>
    Mysql 优化 or
    查看>>
    mysql 优化器 key_mysql – 选择*和查询优化器
    查看>>
    MySQL 优化:Explain 执行计划详解
    查看>>
    Mysql 会导致锁表的语法
    查看>>
    mysql 使用sql文件恢复数据库
    查看>>