圆月山庄资源网 Design By www.vgjia.com
最近在写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问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
圆月山庄资源网 Design By www.vgjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
圆月山庄资源网 Design By www.vgjia.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月02日
2024年11月02日
- 游戏大年背后的风雨摇摆 盘点2024年遭遇裁员的游戏厂商
- 徐小凤.2000-环球2000超巨星系列【环球】【WAV+CUE】
- 余天.2004-二十年来最畅销国语金曲系列2CD【丽歌】【WAV+CUE】
- 完美倒立.2024-夜色碳酸【草台回声】【FLAC分轨】
- 杨青《半山听雨贰HQ》头版限量编号[低速原抓WAV+CUE]
- 白玛多吉《云上西藏1+2》DTS-WAV
- 模拟之声慢刻CD《柏林之声3》[正版CD原抓WAV+CUE]
- 威神V(WayV)《The Highest》[FLAC/分轨][259.1MB]
- 余超颖《迷焕纪》[320K/MP3][201.15MB]
- 余超颖《迷焕纪》[FLAC/分轨][784.22MB]
- 温岚.2005-爱回温新歌加精选2CD【阿尔发】【WAV+CUE】
- 尤雅.1990-台语怀念金曲特选辑【太阳神】【WAV+CUE】
- 群星.2024-七夜雪电视剧影视原声带【听见时代】【FLAC分轨】
- 群星《胎教音乐 古典钢琴曲与水晶摇篮曲》[320K/MP3][134.14MB]
- 群星《胎教音乐 古典钢琴曲与水晶摇篮曲》[FLAC/分轨][654.13MB]