pycharm的python_stubs问题


Posted in Python onApril 08, 2020

最近在写udp socket程序时,对几个函数(如sendto)command+左击时,发现跳转到了这个python文件里面去了。(默认应该是到函数源码那里)

/PyCharm2018.1/python_stubs/160944109/_socket.py

定义了如下的伪函数

def send(self, data, flags=None): # real signature unknown; restored from __doc__
 """
 send(data[, flags]) -> count

 Send a data string to the socket. For the optional flags
 argument, see the Unix manual. Return the number of bytes
 sent; this may be less than len(data) if the network is busy.
 """
 pass

 def sendall(self, data, flags=None): # real signature unknown; restored from __doc__
 """
 sendall(data[, flags])

 Send a data string to the socket. For the optional flags
 argument, see the Unix manual. This calls send() repeatedly
 until all data is sent. If an error occurs, it's impossible
 to tell how much data has been sent.
 """
 pass

google了下,发现已经有人在stackoverflow提出相关问题,我这里简单提炼一下。

https://stackoverflow.com/questions/24266114/pycharm-what-is-python-stubs

什么情况下会出现跳转到python_stubs?

当我们调用的函数是内置函数或仅二进制存在的函数(没有py文件,只有pyc等)时,pycharm会对某个版本进行硬编码而生成的伪函数(实际不是调用的这个,只是方便我们做开发)。

想一想pycharm为了方便我们,真是煞费苦心。

补充知识:Python3自定义日志类 mylog

大家还是直接看代码吧!

#encoding=utf-8

import os, sys
import datetime
import time


class Mylog(object):

 # 根文件夹
 root_dir = sys.path[0]
 # 根目录
 root_path = sys.path[0] + os.path.sep
 # 系统目录分割线
 sys_sep = os.path.sep
 # 配置
 option = {
 # 日志级别: 0:全部,1:调试,2:警告,3:错误
 'level': 0,
 # 是否开启,如果关闭则不输出也不记录日志
 'is_open': True,
 # 是否print输出
 'is_print': True,
 # 是否记录到日志文件
 'is_write': True,
 # 是否在每条日志内容前面加前缀
 'is_prefix': True,
 # 如果开启了每条日志前加前缀,设置日志级别为1的前缀
 'level_1_prefix': 'Test: ',
 # 如果开启了每条日志前加前缀,设置日志级别为2的前缀
 'level_2_prefix': 'Warning: ',
 # 如果开启了每条日志前加前缀,设置日志级别为3的前缀
 'level_3_prefix': 'Error: ',
 # 存放日志文件的根文件夹名称
 'root_dir_name': 'mylog',
 # 自定义存放日志文件的文件名称,此文件夹是在 root_dir_name 文件夹下
 'dir_name': ''
 }

 def __init__(self, config=None):
 if config is not None:
  self.option.update(dict(config))

 # 日志保存的文件夹(全路径)
 save_dir = self.root_path + self.option['root_dir_name']

 # 创建文件夹
 if os.path.isdir(save_dir) is not True:
  os.mkdir(save_dir)
 if len(self.option['dir_name']) > 0:
  save_dir += self.sys_sep + self.option['dir_name']
  if os.path.isdir(save_dir) is not True:
  os.mkdir(save_dir)

 self.save_dir = save_dir
 self.save_path = save_dir + self.sys_sep

 '''
 输入日志/记录日志
 '''
 def log(self, content='', level=0):
 self._print_log(content, level)
 self._write_log(content, level)

 '''
 输入日志
 '''
 def _print_log(self, content, level):
 if self.option['is_open'] is True and self.option['is_print'] is True:
  if self.option['level'] == 0 or self.option['level'] == level:
  if level > 0:
   content = self.option['level_' + str(level) + '_prefix'] + content
  print(content)

 '''
 记录日志
 '''
 def _write_log(self, content, level):
 if self.option['is_open'] is True and self.option['is_print'] is True:
  if self.option['level'] == 0 or self.option['level'] == level:
  if self.option['is_prefix'] is True:
   today = datetime.date.today()
   file_name = str(today) + '.log'
   now = time.strftime("%H:%M:%S")
   log_file = self.save_path + file_name
   if level > 0:
   content = self.option['level_' + str(level) + '_prefix'] + content
   if os.path.isfile(log_file):
   save_file = open(log_file, 'a')
   else:
   save_file = open(log_file, 'w')
   save_file.write(str(now) + "\r\n" + content + "\r\n")
   save_file.close()


 

**重点内容
#!/usr/bin/env python
#-*- coding: GBK -*-
__author__ = 'DiaoHuabin'

import logging
import getpass
import sys

#定义MyLog类
class MyLog(object):
 '''这个类用于创建一个自用的log'''
 def __init__(self): #类MyLog的构造函数
 user = getpass.getuser() #返回用户的登录名
 self.logger = logging.getLogger(user) #返回一个特定名字的日志
 self.logger.setLevel(logging.DEBUG) #对显示的日志信息设置一个阈值低于DEBUG级别的不显示
 logFile = './'+sys.argv[1][0:-3] + '.log' # 日志文件名
 formatter = logging.Formatter('%(asctime)-12s $(levelname)-8s %(name)-10s %(message)-12s')

 '''日志显示到屏幕上并输出到日志文件内'''
 logHand = logging.FileHandler(logFile) #输出日志文件,文件名是logFile
 logHand.setFormatter(formatter) #为logHand以formatter设置格式
 logHand.setLevel(logging.ERROR) #只有错误才被记录到logfile中

 logHandSt = logging.StreamHandler() #class logging.StreamHandler(stream=None)
 # 返回StreamHandler类的实例,如果stream被确定,使用该stream作为日志输出,反之,使用
 #sys.stderr
 logHandSt.setFormatter(formatter) #为logHandSt以formatter设置格式

 self.logger.addHandler(logHand) #添加特定的handler logHand到日志文件logger中
 self.logger.addHandler(logHandSt) #添加特定的handler logHandSt到日志文件logger中

 '''日志的5个级别对应以下的五个函数'''
 def debug(self,msg):
 self.logger.debug(msg) #Logs a message with level DEBUG on this logger.
 # The msg is the message format string

 def info(self,msg):
 self.logger.info(msg)

 def warn(self,msg):
 self.logger.warn(msg)

 def error(self,msg):
 self.logger.error(msg)

 def critical(self,msg):
 self.logger.critical(msg)

if __name__ == '__main__':
 mylogw = MyLog()
 mylogw.debug("I'm debug")
 mylogw.info("I'm info")
 mylogw.warn("I'm warn")
 mylogw.error("I'm error")
 mylogw.critical("I'm critical")

pycharm的python_stubs问题

以上这篇pycharm的python_stubs问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python和C语言混合编程实例
Jun 04 Python
Python进行数据科学工作的简单入门教程
Apr 01 Python
Django ORM框架的定时任务如何使用详解
Oct 19 Python
zookeeper python接口实例详解
Jan 18 Python
Python实现利用163邮箱远程关电脑脚本
Feb 22 Python
用tensorflow搭建CNN的方法
Mar 05 Python
浅谈python中拼接路径os.path.join斜杠的问题
Oct 23 Python
python实现定时发送qq消息
Jan 18 Python
python matplotlib库直方图绘制详解
Aug 10 Python
Python利用逻辑回归模型解决MNIST手写数字识别问题详解
Jan 14 Python
python爬虫scrapy基本使用超详细教程
Feb 20 Python
Python echarts实现数据可视化实例详解
Mar 03 Python
Pycharm中安装Pygal并使用Pygal模拟掷骰子(推荐)
Apr 08 #Python
解决pycharm下pyuic工具使用的问题
Apr 08 #Python
解决pyqt5异常退出无提示信息的问题
Apr 08 #Python
python由已知数组快速生成新数组的方法
Apr 08 #Python
TensorFlow2.X使用图片制作简单的数据集训练模型
Apr 08 #Python
解决python ThreadPoolExecutor 线程池中的异常捕获问题
Apr 08 #Python
使用Python将Exception异常错误堆栈信息写入日志文件
Apr 08 #Python
You might like
php获取服务器端mac和客户端mac的地址支持WIN/LINUX
2014/05/15 PHP
PHP对象相互引用的内存溢出实例分析
2014/08/28 PHP
php实现encode64编码类实例
2015/03/24 PHP
详解thinkphp实现excel数据的导入导出(附完整案例)
2016/12/29 PHP
yii2学习教程之5种内置行为类详解
2017/08/03 PHP
javascript控制frame,iframe的src属性代码
2009/12/31 Javascript
基于jQuery的可用于选项卡及幻灯的切换插件
2011/03/28 Javascript
jQuery LigerUI 使用教程入门篇
2012/01/18 Javascript
jQuery图片播放8款精美插件分享
2013/02/17 Javascript
JS分页控件 可用于无刷新分页
2013/07/23 Javascript
利用jQuery实现可输入搜索文字的下拉框
2013/10/23 Javascript
jQuery 滑动方法slideDown向下滑动元素
2014/01/16 Javascript
基于JQuery实现滚动到页面底端时自动加载更多信息
2014/01/31 Javascript
使用CSS3的scale实现网页整体缩放
2014/03/18 Javascript
jquery+ajax实现直接提交表单实例分析
2016/06/17 Javascript
JS调用打印机功能简单示例
2016/11/28 Javascript
微信小程序组件之srcoll-view的详解
2017/10/19 Javascript
Angularjs Promise实例详解
2018/03/15 Javascript
关于vue状态过渡transition不起作用的原因解决
2019/04/09 Javascript
微信小程序自定义菜单切换栏tabbar组件代码实例
2019/12/30 Javascript
Vue封装Axios请求和拦截器的步骤
2020/09/16 Javascript
JavaScript检测是否开启了控制台(F12调试工具)
2020/10/02 Javascript
python中 ? : 三元表达式的使用介绍
2013/10/09 Python
Python cookbook(数据结构与算法)在字典中将键映射到多个值上的方法
2018/02/18 Python
解决django无法访问本地static文件(js,css,img)网页里js,cs都加载不了
2020/04/07 Python
python和php学习哪个更有发展
2020/06/17 Python
Django配置跨域并开发测试接口
2020/11/04 Python
termux中matplotlib无法显示中文问题的解决方法
2021/01/11 Python
python 使用openpyxl读取excel数据
2021/02/18 Python
利用Opencv实现图片的油画特效实例
2021/02/28 Python
瑞士香水购物网站:Parfumcity.ch
2017/01/14 全球购物
澳大利亚当地社区首选的光学商店:1001 Optical
2019/08/24 全球购物
无传销社区工作方案
2014/05/13 职场文书
责任书格式范文
2014/07/28 职场文书
2014年社区宣传工作总结
2014/12/02 职场文书
工程资料员岗位职责
2015/04/13 职场文书