python语言 python打印当前函数名称和行号示例

本文展示了如何在Python中利用`inspect`模块获取当前函数的名称和行号。通过示例代码,解释了`get_head_info()`函数的工作原理,并在`call_func()`中调用。此外,还探讨了`import`、`from...import`的区别,以及`reload`函数的作用。最后,提到了动态导入模块的`__import__`函数。
摘要由CSDN通过智能技术生成

示例demo:

#!/usr/bin/env python

import os
import sys
import inspect
import logging

from datetime import *

def get_head_info():
     try:
         raise Exception
     except:
         f = sys.exc_info()[2].tb_frame.f_back
     return '%s, %s, %s, %s, ' % (str(datetime.now()), f.f_code.co_filename, f.f_code.co_name, str(f.f_lineno))

def call_func():
    print '%s --> skdkjzz' % (get_head_info())

def main():
    call_func();

if __name__ == '__main__':
     sys.exit(main())   

运行效果如下:

2014-12-26 09:57:23.464724, headinfo_py, call_func, 18,  --> skdkjzz

注:

1、import与from xxx import *区别

import
作用:
导入/引入一个python标准模块,其中包括.py文件、带有__init__.py文件的目录。
e.g:

[python] view plain copy print ?
  1. import module_name[,module1,...]  
  2. from module import *|child[,child1,...]  
<span style="font-size:12px;">import module_name[,module1,...]
from module import *|child[,child1,...]</span>

说明:
多次重复使用import语句时,不会重新加载被指定的模块,只是把对该模块的内存地址给引用到本地变量环境。
测试:

[python] view plain copy print ?
  1. a.py  
  2. #!/usr/bin/env python    
  3. #encoding: utf-8  
  4. import os  
  5. print '
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值