2024-08-27

gc模块是Python的垃圾收集器,它用于管理内存中的对象。当Python中的对象没有任何引用时,这些对象就变得不可达,然后就可以被垃圾收集器回收。

以下是一些常用的gc模块函数:

  1. gc.set_debug(): 这个函数可以用来设置垃圾收集器的调试标记。
  2. gc.collect(): 这个函数可以用来强制进行一次垃圾收集。
  3. gc.get_objects(): 这个函数可以用来获取一个包含所有现存对象的列表。
  4. gc.disable(): 这个函数可以用来禁用垃圾收集器。
  5. gc.enable(): 这个函数可以用来启用垃圾收集器。
  6. gc.isenabled(): 这个函数可以用来检查垃圾收集器是否已经启用。

示例代码:




import gc
 
# 设置垃圾收集器的调试标记
gc.set_debug(gc.DEBUG_LEAK)
 
# 获取当前对象的列表
objects = gc.get_objects()
 
# 打印所有对象的数量
print("Before collect: {} objects".format(len(objects)))
 
# 强制进行一次垃圾收集
gc.collect()
 
# 再次获取当前对象的列表
objects = gc.get_objects()
 
# 打印收集后的对象数量
print("After collect: {} objects".format(len(objects)))

这个代码首先设置垃圾收集器的调试标记,然后获取当前所有的对象,打印出对象的数量。之后进行一次垃圾收集,再次获取对象列表,并打印出收集后的对象数量。这可以帮助我们了解垃圾收集器的工作情况。

2024-08-27



# 导入fileinput模块
import fileinput
import sys
 
# 设置标准输入为fileinput模块,这样我们就可以通过命令行传入文件进行处理
sys.stdin = fileinput.input()
 
# 主处理函数,对标准输入进行处理
def process_input():
    for line in sys.stdin:
        # 对每一行进行处理,这里只是打印出来,实际应用中可以根据需要修改
        print(line.upper())  # 将输入转换为大写
 
# 如果是作为脚本直接运行,则执行主处理函数
if __name__ == "__main__":
    process_input()

这段代码演示了如何使用Python的fileinput模块来创建一个简单的命令行文本处理器。它接受命令行输入,并将其转换为大写然后输出。这个例子是一个基础的模板,可以根据具体需求进行功能扩展。

2024-08-27

在Python中,日期和时间可以使用内置的datetime模块来处理。以下是一些常用的操作和示例代码:

  1. 获取当前日期和时间:



from datetime import datetime
 
now = datetime.now()
print("现在的日期和时间:", now)
  1. 格式化日期和时间:



formatted_now = now.strftime("%Y-%m-%d %H:%M:%S")
print("格式化后的日期和时间:", formatted_now)
  1. 日期时间的加减:



# 加上一天
next_day = now + timedelta(days=1)
print("明天的日期和时间:", next_day)
 
# 减去一小时
previous_hour = now - timedelta(hours=1)
print("一个小时前的时间:", previous_hour)
  1. 解析字符串为日期时间:



datestring = "2023-03-25 10:00:00"
parsed_date = datetime.strptime(datestring, "%Y-%m-%d %H:%M:%S")
print("解析后的日期和时间:", parsed_date)

确保你的环境中已经安装了Python,并且你正在使用Python 3.x版本。上述代码可以直接复制粘贴到Python文件中运行。

2024-08-27

在Python中,site模块用于提供与当前运行的Python站点相关的配置信息。这个模块通常不用于常规的编程任务,而是用于Python环境的初始化和管理。

如果你需要查看或获取与Python站点相关的配置信息,你可以使用以下方式:




import site
 
# 打印所有已知的路径
for path in site.getsitepackages():
    print(path)
 
# 打印用户站点包目录
print(site.getusersitepackages())
 
# 打印全局站点包目录
print(site.getsitepackages()[0])
 
# 打印用于用户级别的配置文件路径
print(site.getuserbase())
 
# 打印所有的路径,用于搜索模块
for path in site.getpaths():
    print(f"{path}: {getattr(site, path)}")

这个代码展示了如何使用site模块来获取Python环境的相关路径信息。这些信息对于理解Python如何查找模块和包是很有帮助的。

请注意,site模块的用途是为Python的启动和运行时配置进行的,通常不建议在普通的应用程序中直接使用。如果你需要处理应用程序的路径或配置,应该使用标准的配置文件或环境变量,而不是依赖site模块。

2024-08-27

shlex 模块提供了一个类 shlex,它可以用来处理或解析类似 Shell 的字符串,这些字符串通常在命令行中输入,或者在配置文件或脚本中以字符串形式出现。

以下是一些使用 shlex 模块的常见方法:

  1. 使用 shlex.split() 方法来分割字符串:

shlex.split() 方法可以将一个字符串分割成一个字符串列表,这个列表可以被系统调用来运行一个子进程。




import shlex
 
command = 'ls -l /home/user'
args = shlex.split(command)
print(args)
# 输出: ['ls', '-l', '/home/user']
  1. 使用 shlex.shlex() 类来自定义分割行为:

shlex() 类可以用来创建一个新的分析器,它可以被用来自定义如何分割字符串。




import shlex
 
command = 'ls -l /home/user'
lex = shlex.shlex(command)
lex.whitespace += ','
print(list(lex))
# 输出: ['ls', '-l', '/home/user']
  1. 使用 shlex.quote() 方法来引用字符串:

shlex.quote() 方法可以用来将字符串包围起来,以便它可以安全地用作一个命令行参数。




import shlex
 
print(shlex.quote('Hello, World!'))
# 输出: 'Hello, World!'

以上就是 shlex 模块的一些基本用法。

2024-08-27



from datetime import datetime
 
# 获取当前日期和时间
now = datetime.now()
print("当前日期和时间:", now)
 
# 获取当前年份
year = now.year
print("年份:", year)
 
# 获取当前月份
month = now.month
print("月份:", month)
 
# 获取当前日期
day = now.day
print("日期:", day)
 
# 获取当前小时
hour = now.hour
print("小时:", hour)
 
# 获取当前分钟
minute = now.minute
print("分钟:", minute)
 
# 获取当前秒
second = now.second
print("秒:", second)
 
# 打印特定格式的日期和时间
formatted_datetime = now.strftime("%Y-%m-%d %H:%M:%S")
print("格式化日期和时间:", formatted_datetime)
 
# 解析字符串为日期时间
parsed_datetime = datetime.strptime("2023-03-25 15:30:00", "%Y-%m-%d %H:%M:%S")
print("解析的日期和时间:", parsed_datetime)

这段代码展示了如何使用Python的datetime模块来获取当前的日期和时间,并进行格式化输出。同时,还展示了如何将特定格式的字符串解析为日期时间对象。

2024-08-27

在Python中,可以使用import语句来导入模块。例如,要导入内置的math模块,可以这样做:




import math

如果只需要导入模块中的特定函数或变量,可以使用from...import...语句:




from math import sqrt

这样,就只会导入math模块中的sqrt函数。

如果要导入模块并给其指定别名,可以使用as关键字:




import math as m
from math import sqrt as sq

在这里,math模块被导入并分别赋予了msq别名。

还可以使用importlib模块在运行时动态导入模块:




import importlib
math = importlib.import_module('math')

这样,就可以在运行时根据变量名来导入相应的模块。

2024-08-27

以下是一个Python脚本示例,用于从多个CSV文件中提取指定行的数据,并将结果保存到一个新的CSV文件中。




import os
import csv
from glob import glob
 
# 设置源CSV文件路径、目标CSV文件路径和需要提取的行索引
source_csv_folder = 'path/to/csv/files'  # CSV文件所在文件夹路径
target_csv_file = 'path/to/output.csv'  # 目标CSV文件路径
rows_to_extract = [0, 2]  # 需要提取的行索引列表,例如提取第0行和第2行
 
# 从所有CSV文件中提取指定行,并保存到目标CSV文件
with open(target_csv_file, 'w', newline='') as out_csv:
    csv_writer = csv.writer(out_csv)
    for file_path in glob(os.path.join(source_csv_folder, '*.csv')):
        with open(file_path, 'r') as in_csv:
            csv_reader = csv.reader(in_csv)
            for row_index, row in enumerate(csv_reader):
                if row_index in rows_to_extract:
                    csv_writer.writerow(row)

确保将source_csv_folder变量设置为包含CSV文件的文件夹路径,target_csv_file设置为要创建的新CSV文件的路径,rows_to_extract设置为你想要提取的行索引列表。

此脚本会遍历指定文件夹内所有CSV文件,提取指定的行,并将结果保存到target_csv_file指定的新CSV文件中。

2024-08-27



from PyQt5.QtWidgets import QApplication, QMainWindow, QVBoxLayout, QPushButton
from PyQt5.QtCore import Qt
 
class MainWindow(QMainWindow):
    def __init__(self):
        super().__init__()
        self.setWindowTitle("鼠标键盘联动示例")
        self.setGeometry(100, 100, 400, 200)
        self.layout = QVBoxLayout()
 
        self.button = QPushButton("点击我")
        self.button.clicked.connect(self.button_clicked)
 
        self.setCentralWidget(self.button)
 
    def button_clicked(self):
        # 鼠标点击事件处理逻辑
        print("按钮被点击")
 
 
def main():
    app = QApplication([])
    window = MainWindow()
    window.show()
    app.exec_()
 
 
if __name__ == '__main__':
    main()

这段代码创建了一个PyQt5应用,其中包含一个主窗口和一个按钮。按钮被点击时,会触发button_clicked方法,并在控制台打印出相应的信息。这个简单的例子展示了如何在PyQt5中处理鼠标和键盘事件,并实现与用户界面的交互。

2024-08-26



from Crypto.PublicKey import RSA
from Crypto.Cipher import PKCS1_v1_5 as Cipher_pkcs1_v1_5
from Crypto.Signature import PKCS1_v1_5 as Signature_pkcs1_v1_5
from Crypto.Hash import SHA256
from base64 import b64encode, b64decode
 
# 生成RSA密钥对
key = RSA.generate(2048)
public_key = key.publickey()
 
# 加密
def encrypt(text):
    cipher = Cipher_pkcs1_v1_5.new(public_key)
    return b64encode(cipher.encrypt(text.encode('utf-8'))).decode('utf-8')
 
# 解密
def decrypt(text):
    cipher = Cipher_pkcs1_v1_5.new(key)
    return cipher.decrypt(b64decode(text.encode('utf-8')), b'').decode('utf-8')
 
# 签名
def sign(text):
    h = SHA256.new()
    h.update(text.encode('utf-8'))
    signer = Signature_pkcs1_v1_5.new(key)
    return b64encode(signer.sign(h)).decode('utf-8')
 
# 验证签名
def verify(text, signature):
    h = SHA256.new()
    h.update(text.encode('utf-8'))
    verifier = Signature_pkcs1_v1_5.new(public_key)
    return verifier.verify(h, b64decode(signature.encode('utf-8')))
 
# 使用示例
plaintext = "Hello, World!"
encrypted = encrypt(plaintext)
decrypted = decrypt(encrypted)
signed_data = sign(plaintext)
print(f"Original: {plaintext}")
print(f"Encrypted: {encrypted}")
print(f"Decrypted: {decrypted}")
print(f"Signed: {signed_data}")
assert verify(plaintext, signed_data), "Signature verification failed"
print("Signature verified successfully")

这段代码展示了如何使用PyCrypto库进行RSA加密、解密、签名和验证。首先生成了一个2048位的RSA密钥对,然后提供了encryptdecryptsignverify函数来执行这些操作。最后,我们用一个示例来展示如何使用这些函数。