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 相关文章推荐
在Docker上部署Python的Flask框架的教程
Apr 08 Python
在Mac OS上搭建Python的开发环境
Dec 24 Python
Python利用Beautiful Soup模块搜索内容详解
Mar 29 Python
python dlib人脸识别代码实例
Apr 04 Python
python中类的输出或类的实例输出为这种形式的原因
Aug 12 Python
解决Tensorflow 使用时cpu编译不支持警告的问题
Feb 03 Python
numpy 矩阵形状调整:拉伸、变成一位数组的实例
Jun 18 Python
Pandas的Apply函数具体使用
Jul 21 Python
Python3.7安装pyaudio教程解析
Jul 24 Python
mac安装python3后使用pip和pip3的区别说明
Sep 01 Python
Python编写可视化界面的全过程(Python+PyCharm+PyQt)
May 17 Python
python通过新建环境安装tfx的问题
May 20 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
上传文件先创建目录 再上传到目录里面去
2010/12/29 PHP
mac下安装nginx和php
2013/11/04 PHP
php5.4传引用时报错问题分析
2016/01/22 PHP
PHP遍历目录文件的常用方法小结
2017/02/03 PHP
PHP和MYSQL实现分页导航思路详解
2017/04/11 PHP
轻轻松松学习JavaScript
2007/02/25 Javascript
JavaScript 学习初步 入门教程
2010/03/25 Javascript
javascript中的对象创建 实例附注释
2011/02/08 Javascript
js 编程笔记 无名函数
2011/06/28 Javascript
详解JavaScript实现设计模式中的适配器模式的方法
2016/05/18 Javascript
AngularJS基础 ng-dblclick 指令用法
2016/08/01 Javascript
Angularjs 事件指令详细整理
2017/07/27 Javascript
三分钟教你用Node做一个微信哄女友(基友)神器(面向小白)
2019/06/21 Javascript
Vue + element 实现多选框组并保存已选id集合的示例代码
2020/06/03 Javascript
[02:38]2018DOTA2亚洲邀请赛赛前采访-VGJ.T
2018/04/03 DOTA
详解Python命令行解析工具Argparse
2016/04/20 Python
Python基础语言学习笔记总结(精华)
2017/11/14 Python
numpy使用技巧之数组过滤实例代码
2018/02/03 Python
使用python3+xlrd解析Excel的实例
2018/05/04 Python
python json.dumps中文乱码问题解决
2020/04/01 Python
Python sql注入 过滤字符串的非法字符实例
2020/04/03 Python
如何快速理解python的垃圾回收机制
2020/09/01 Python
全方位了解CSS3的Regions扩展
2015/08/07 HTML / CSS
世界顶级俱乐部的官方球衣和套装:Subside Sports
2018/04/22 全球购物
Ibatis中如何提高SQL Map的性能
2013/05/11 面试题
大专生自我评价
2014/01/28 职场文书
报关专员求职信范文
2014/02/22 职场文书
2014年毕业演讲稿范文
2014/05/13 职场文书
省委召开党的群众路线教育实践活动总结大会报告
2014/10/21 职场文书
2014年销售工作总结范文
2014/12/01 职场文书
2014年学校后勤工作总结
2014/12/06 职场文书
2015年社区综治宣传月活动总结
2015/03/25 职场文书
旷工检讨书大全
2015/08/15 职场文书
庆祝教师节主题班会
2015/08/17 职场文书
评测 | 大屏显示带收音机的高端音箱,JBL TUNE2便携式插卡音箱实测
2021/04/24 无线电
MySQL查看表和清空表的常用命令总结
2021/05/26 MySQL