当前位置: 首页 > news >正文

注意,摸鱼程序员常用的9个小技巧,早点下班不秃头

9个养生小技巧,祝大家不秃头

      • 嗨害大家好鸭! 我是小熊猫~
        • 毕竟摸鱼一时爽,一直摸一直爽嘛~
      • 一、整理字符串输入
      • 二、迭代器切片(Slice)
      • 三、跳过可迭代对象的开头
      • 四、只包含关键字参数的函数 (kwargs)
      • 五、创建支持「with」语句的对象
      • 六、用`「slots」`节省内存
      • 七、限制`「CPU」`和内存使用量
      • 八、控制可以/不可以导入什么
      • 九、实现比较运算符的简单方法

嗨害大家好鸭! 我是小熊猫~

作为一个python程序员

小熊猫我鸭每天都在想怎么才能养生

毕竟这头发掉得确实是有点让人害怕

请添加图片描述

最近从前辈那里习来的8个小技巧

说是能让我小熊猫不秃头,

这种好东西肯定要分享出来给大家快乐快乐~

毕竟摸鱼一时爽,一直摸一直爽嘛~

python其他资料电子书:点击此处跳转文末名片获取

在这里插入图片描述


一、整理字符串输入

整理用户输入的问题在编程过程中极为常见。
通常情况下,
将字符转换为小写或大写就够了,
有时你可以使用正则表达式模块「Regex」完成这项工作。
但是如果问题很复杂,
可能有更好的方法来解决:

user_input = "This\nstring has\tsome whitespaces...\r\n"character_map = {#python学习交流扣扣qun:540305994ord('\n') : ' ',ord('\t') : ' ',ord('\r') : None
}
user_input.translate(character_map)  # This string has some whitespaces... 

在本例中,
你可以看到空格符「\ n」和「\ t」都被替换成了单个空格,
「\ r」都被删掉了。
这只是个很简单的例子,
我们可以更进一步,
使用「unicodedata」程序包生成大型重映射表,
并使用其中的「combining()」进行生成和映射,

二、迭代器切片(Slice)

如果对迭代器进行切片操作,
会返回一个「TypeError」,
提示生成器对象没有下标,
但是我们可以用一个简单的方案来解决这个问题:

import itertoolss = itertools.islice(range(50), 10, 20)  # <itertools.islice object at 0x7f70fab88138>
for val in s:...

我们可以使用「itertools.islice」创建一个「islice」对象,
该对象是一个迭代器,
可以产生我们想要的项。
但需要注意的是,
该操作要使用切片之前的所有生成器项,
以及「islice」对象中的所有项。

三、跳过可迭代对象的开头

有时你要处理一些以不需要的行(如注释)开头的文件。

「itertools」再次提供了一种简单的解决方案:

string_from_file = """
// Author: ...
// License: ...
//
// Date: ...
Actual content...
"""
#python学习交流扣扣qun:540305994
import itertoolsfor line in itertools.dropwhile(lambda line: line.startswith("//"), string_from_file.split("\n")):print(line)

这段代码只打印初始注释部分之后的内容。
如果我们只想舍弃可迭代对象的开头部分
(本示例中为开头的注释行),
而又不知道要这部分有多长时,
这种方法就很有用了。

四、只包含关键字参数的函数 (kwargs)

当我们使用下面的函数时,
创建仅仅需要关键字参数
作为输入的函数来提供更清晰的函数定义,
会很有帮助:

def test(*, a, b):passtest("value for a", "value for b")  # TypeError: test() takes 0 positional arguments...
test(a="value", b="value 2")  # Works...

如你所见,
在关键字参数之前加上一个「」就可以解决这个问题。
如果我们将某些参数放在「」参数之前,
它们显然是位置参数。

五、创建支持「with」语句的对象

举例而言,
我们都知道如何使用「with」语句打开文件或获取锁,
但是我们可以实现自己上下文表达式吗?
是的,
我们可以使用「enter」和「exit」来实现上下文管理协议:

class Connection:def __init__(self):...def __enter__(self):def __exit__(self, type, value, traceback):with Connection() as c:

这是在 Python 中最常见的实现上下文管理的方法,
但是还有更简单的方法:

from contextlib import contextmanager@contextmanager
def tag(name):print(f"<{name}>")yieldprint(f"</{name}>")with tag("h1"):print("This is Title.")

上面这段代码使用
contextmanager manager 装饰器实现了内容管理协议。
在进入 with 块时 tag 函数的第一部分
(在 yield 之前的部分)就已经执行了,
然后with块才被执行,
最后执行 tag 函数的其余部分。

请添加图片描述

六、用「slots」节省内存

如果你曾经编写过一个创建了某种类的大量实例的程序,
那么你可能已经注意到,
你的程序突然需要大量的内存。
那是因为 Python 使用字典来表示类实例的属性,
这使其速度很快,但内存使用效率却不是很高。
通常情况下,这并不是一个严重的问题。
但是,如果你的程序因此受到严重的影响,
不妨试一下「slots」

class Person:__slots__ = ["first_name", "last_name", "phone"]def __init__(self, first_name, last_name, phone):self.first_name = first_nameself.last_name = last_nameself.phone = phone

当我们定义了「slots」属性时,
Python 没有使用字典来表示属性,
而是使用小的固定大小的数组,
这大大减少了每个实例所需的内存。
使用「slots」也有一些缺点:
我们不能声明任何新的属性,
我们只能使用「slots」上现有的属性。
而且,带有「slots」的类不能使用多重继承。

七、限制「CPU」和内存使用量

如果不是想优化程序对内存或 CPU 的使用率,
而是想直接将其限制为某个确定的数字,
Python 也有一个对应的库可以做到:

import signal
import resource
import osdef time_exceeded(signo, frame):print("CPU exceeded...")raise SystemExit(1)def set_max_runtime(seconds):soft, hard = resource.getrlimit(resource.RLIMIT_CPU)resource.setrlimit(resource.RLIMIT_CPU, (seconds, hard))signal.signal(signal.SIGXCPU, time_exceeded)def set_max_memory(size):soft, hard = resource.getrlimit(resource.RLIMIT_AS)resource.setrlimit(resource.RLIMIT_AS, (size, hard))

我们可以看到,在上面的代码片段中,
同时包含设置最大 CPU 运行时间和最大内存使用限制的选项。

在限制 CPU 的运行时间时,
我们首先获得该特定资源(RLIMIT_CPU)的软限制和硬限制,

然后使用通过参数指定的秒数和先前检索到的硬限制来进行设置。

最后,如果 CPU 的运行时间超过了限制,

我们将发出系统退出的信号。

在内存使用方面,我们再次检索软限制和硬限制,

并使用带「size」参数的「setrlimit」和先前检索到的硬限制来设置它。

八、控制可以/不可以导入什么

有些语言有非常明显的机制来导出成员(变量、方法、接口),

例如在 Golang 中只有以大写字母开头的成员被导出。

然而,在 Python 中,
所有成员都会被导出(除非我们使用了「all」):

def foo():passdef bar():pass__all__ = ["bar"]

在上面这段代码中,
我们知道只有「bar」函数被导出了。
同样,我们可以让「all」为空,
这样就不会导出任何东西,
当从这个模块导入的时候,
会造成「AttributeError」。

九、实现比较运算符的简单方法

为一个类实现所有的比较运算符(如 lt , le , gt , ge
是很繁琐的。
有更简单的方法可以做到这一点吗?
这种时候,
「functools.total_ordering」就是一个很好的帮手:

from functools import total_ordering@total_ordering
class Number:def __init__(self, value):self.value = valuedef __lt__(self, other):return self.value < other.valuedef __eq__(self, other):return self.value == other.valueprint(Number(20) > Number(3))
print(Number(1) < Number(5))
print(Number(15) >= Number(15))
print(Number(10) <= Number(2))

这里的工作原理究竟是怎样的呢?
我们用「total_ordering」装饰器简化实现对类实例排序的过程。

我们只需要定义「lt」「eq」就可以了,
它们是实现其余操作所需要的最小的操作集合
(这里也体现了装饰器的作用——为我们填补空白)。

请添加图片描述

👇问题解答 · 源码获取 · 技术交流 · 抱团学习请联系👇

http://www.lryc.cn/news/24890.html

相关文章:

  • 【Linux】文件时间-ACM
  • [架构之路-124]-《软考-系统架构设计师》-操作系统-3-操作系统原理 - IO设备、微内核、嵌入式系统
  • 【竞赛/TPU】算能TPU编程竞赛总结
  • Substrate 基础教程(Tutorials) -- 模拟网络 添加可信节点
  • SAP 设置无物料号的费用采购
  • k8s ConfigMap 中 subPath 字段和 items 字段
  • UML建模
  • JavaScript常见面试题(更新中)
  • TCP/IP协议
  • Python使用异步线程池实现异步TCP服务器交互
  • matplotlib常用操作
  • 二分算法题
  • Vue+ElementUI+SpringBoot项目配合分页插件快速实现分页(简单暴力)
  • 【回眸】牛客网刷刷刷!嵌入式软件中也会遇到的嵌入式硬件,通讯,通讯协议专题(一)
  • 使用Vue展示数据(动态查询)
  • 构建数据库测试数据——mysql
  • 你想要的Android性能优化系列:启动优化 !
  • python3的基础入门3:基本数据类型
  • 消息队列原理与实战-学习笔记
  • Linux权限相关知识(大量图文展示,及详细操作)
  • Ep_操作系统面试题-什么是协程
  • 在C#中使用互斥量解决多线程访问共享资源的冲突问题
  • JavaEE进阶第六课:SpringBoot配置文件
  • MySQL基础(一)SQL分类、导入、SELECT语句,运算符
  • 反激与正激的区别
  • 王道操作系统课代表 - 考研计算机 第四章 文件管理 究极精华总结笔记
  • 前端开发规范,你真的了解吗?一起来学习一下前端开发规范,让你的代码高级起来!
  • Licode—基于webrtc的SFU/MCU实现
  • 开发运维工具推荐 --- 解决远程访问局域网服务的问题。开发调试推荐
  • 【华为OD机试 】单词倒序(C++ Java JS Python)