2024-08-25



import openpyxl
from openpyxl.styles import PatternFill
 
# 假设df是一个Pandas DataFrame,其中包含需要合并的行
# 假设df有'A'列,我们将根据'A'列的值进行分组,并合并相应的单元格
 
def merge_cells_in_column(sheet, column, start_row, end_row, fill=None):
    # 在指定列的指定行范围内合并单元格
    for row in sheet[column][start_row:end_row]:
        for cell in row:
            if fill:
                cell.fill = fill
            cell.merge = True
 
def groupby_and_merge(df, column_to_groupby, sheet_name='Sheet1', fill=None):
    # 创建一个新的Excel工作簿
    wb = openpyxl.Workbook()
    ws = wb.active
    ws.title = sheet_name
 
    # 根据groupby列的值进行分组并保存
    for group, data in df.groupby(column_to_groupby):
        # 将数据写入工作表
        for row_index, row in data.iterrows():
            for col_index, value in row.items():
                ws.cell(row=row_index+1, column=col_index+1).value = value
        
        # 合并相同的组名所在的单元格
        start_row = 1  # 从第一行开始
        end_row = len(data) + 1  # 到数据结束的下一行
        merge_cells_in_column(ws, column_to_groupby, start_row, end_row, fill)
 
    # 保存工作簿
    wb.save('merged_cells.xlsx')
 
# 示例DataFrame和groupby调用
# df = pandas.DataFrame({'A': ['foo', 'bar', 'foo', 'bar'], 'B': [1, 2, 3, 4]})
# groupby_and_merge(df, 'A')

这段代码定义了两个函数:merge_cells_in_columngroupby_and_mergemerge_cells_in_column 函数负责合并指定列的单元格,而 groupby_and_merge 函数则根据Pandas DataFrame中的某一列进行分组,并对每个组名所在的单元格进行合并。在示例DataFrame和groupby调用部分,可以通过更改DataFrame和列名来实现不同的合并需求。

2024-08-25

在Python中,通过Pillow库可以轻松调整图像的大小。Pillow是一个强大的图像处理库,可以用于打开、处理和保存各种格式的图片。其中,resize()方法用于调整图像的大小。

以下是一些使用Pillow库的resize()方法的示例:

  1. 调整图像到固定大小:



from PIL import Image
 
img = Image.open('path_to_your_image.jpg')
resized_img = img.resize((128, 128))  # 将图像大小调整为128x128
resized_img.save('resized_image.jpg')
  1. 调整图像的宽度或高度,保持其宽高比:



from PIL import Image
 
img = Image.open('path_to_your_image.jpg')
resized_img = img.resize((128, 0))  # 将图像的宽度调整为128,高度自动保持宽高比
resized_img.save('resized_image.jpg')
  1. 使用Image.BICUBICImage.LANCZOS插值方法调整图像大小:



from PIL import Image
 
img = Image.open('path_to_your_image.jpg')
resized_img = img.resize((128, 128), Image.BICUBIC)  # 使用双三次插值方法调整图像大小
resized_img.save('resized_image.jpg')
  1. 使用resize()方法保持图像质量:



from PIL import Image
 
img = Image.open('path_to_your_image.jpg')
resized_img = img.resize((128, 128), Image.ANTIALIAS)  # 使用抗锯齿插值方法调整图像大小
resized_img.save('resized_image.jpg')

以上代码演示了如何使用Pillow库中的resize()方法调整图像大小。你可以根据需要选择合适的插值方法和图像大小。

2024-08-25

首先,确保安装了gmssl包。如果没有安装,可以使用pip进行安装:




pip install gmssl

以下是使用gmssl进行SM2加密和解密的示例代码:




import gmssl
from gmssl import sm2
from gmssl import func
 
# 生成SM2密钥对
(sk, pk) = sm2.generate_params()
 
# 将私钥和公钥转换为十六进制字符串
sk_hex = sm2.int_to_hex(sk)
pk_hex = sm2.int_to_hex(pk)
 
# 需要加密的数据
data = b"Hello, SM2!"
 
# 对数据进行加密
cipher_text = sm2.encrypt(pk, data)
cipher_text_hex = sm2.bytes_to_hex(cipher_text)
 
# 对数据进行解密
decrypted_text = sm2.decrypt(sk, cipher_text)
 
print(f"Original Data: {data}")
print(f"Cipher Text (hex): {cipher_text_hex}")
print(f"Decrypted Data: {decrypted_text}")

这段代码展示了如何生成SM2密钥对、如何加密数据、如何将加密后的数据转换为十六进制字符串,以及如何对十六进制字符串进行解密。在实际应用中,私钥应当严格保管,而公钥可以公开给需要通信的其他方。

2024-08-25



import pandas as pd
 
# 创建一个简单的DataFrame
data = {'Name': ['John', 'Anna', 'Peter', 'Linda'],
        'Age': [28, 23, 34, 29]}
df = pd.DataFrame(data)
 
# 打印DataFrame
print(df)
 
# 将DataFrame导出到CSV文件
df.to_csv('output.csv', index=False)
 
# 从CSV文件读取数据到新的DataFrame
df_from_csv = pd.read_csv('output.csv')
 
# 打印新的DataFrame
print(df_from_csv)

这段代码展示了如何使用pandas库创建一个简单的DataFrame,并对其进行打印和导出到CSV文件操作。然后,它展示了如何从CSV文件读取数据到新的DataFrame,并打印出来。这个过程是数据处理和分析的常见步骤,pandas库提供了丰富的功能来处理这些操作。

2024-08-25



# 导入需要的模块
import time
from selenium import webdriver
from selenium.webdriver.common.keys import Keys
 
# 打开浏览器并访问指定的网址
driver = webdriver.Chrome()
driver.get('http://www.yourwebsite.com/')
 
# 找到登录用户名和密码输入框,输入用户名和密码
username = driver.find_element_by_id('username')
password = driver.find_element_by_id('password')
username.send_keys('your_username')
password.send_keys('your_password')
 
# 找到登录按钮,并点击登录
login_button = driver.find_element_by_id('login_button')
login_button.click()
 
# 等待登录后的页面加载完成
time.sleep(5)
 
# 进入刷量页面
driver.get('http://www.yourwebsite.com/dolist')
 
# 找到刷量输入框,并输入刷量内容
content_input = driver.find_element_by_id('content_input')
content_input.send_keys('Your content here')
 
# 执行刷量操作
submit_button = driver.find_element_by_id('submit_button')
submit_button.click()
 
# 关闭浏览器
time.sleep(5)
driver.quit()

这段代码使用了Selenium WebDriver来自动化浏览器操作。它打开了一个新的Chrome浏览器窗口,访问了指定的网址,并进行了登录操作。然后,它访问刷量页面,并输入了刷量内容后提交。最后,它在等待一段时间后关闭了浏览器窗口,释放了相关资源。这个脚本提供了一个简单的模板,可以根据实际的网站和需求进行修改和调整。

2024-08-25



import time
from concurrent.futures import ThreadPoolExecutor, ProcessPoolExecutor
 
# 定义一个函数,模拟耗时任务
def long_running_task(task_name, delay):
    print(f"任务 {task_name} 开始执行")
    time.sleep(delay)  # 模拟耗时操作
    print(f"任务 {task_name} 执行完成")
    return f"任务 {task_name} 的结果"
 
# 使用多线程执行任务
def run_with_threads(tasks):
    with ThreadPoolExecutor(max_workers=4) as executor:
        results = executor.map(long_running_task, tasks.keys(), tasks.values())
        for result in results:
            print(result)
 
# 使用多进程执行任务
def run_with_processes(tasks):
    with ProcessPoolExecutor() as executor:
        results = {executor.submit(long_running_task, task, delay): task for task, delay in tasks.items()}
        for future in executor.as_completed(results):
            task = results[future]
            try:
                data = future.result()
                print(data)
            except Exception as e:
                print(f"任务 {task} 执行出错: {e}")
 
# 示例使用
tasks = {'task1': 2, 'task2': 4, 'task3': 6, 'task4': 8}
run_with_threads(tasks)
print("\n")
run_with_processes(tasks)

这段代码定义了一个模拟耗时任务的函数long_running_task,以及两个函数run_with_threadsrun_with_processes,分别用于使用多线程和多进程并发执行这些任务。run_with_threads使用ThreadPoolExecutor来执行任务,而run_with_processes使用ProcessPoolExecutor。两个函数都通过迭代传入的任务字典来启动并执行任务,并打印出任务结果或错误信息。

2024-08-25

要将深度图和RGB图像转换为点云,你可以使用OpenCV库和numpy库。以下是一个Python示例代码,展示了如何将深度图和RGB图像转换为3D点云:




import numpy as np
import cv2
import open3d as o3d
 
# 读取深度图和RGB图像
depth_image = cv2.imread("depth.png", cv2.IMREAD_UNCHANGED)
rgb_image = cv2.imread("rgb.jpg")
 
# 获取相机内参(假设为相同的内参矩阵)
fx = 525.0  # 焦距
fy = 525.0
cx = 319.5
cy = 239.5
 
# 深度图转换为距离图
depth_image = depth_image.astype(np.float32) / 65535.0  # 将16位无符号整数转为32位浮点数,并归一化
distance = (1.0 / depth_image) - 1.0  # 深度图转距离图
 
# 创建点云
point_cloud = o3d.geometry.PointCloud()
 
# 遍历深度图像,计算3D坐标
for v in range(depth_image.shape[0]):
    for u in range(depth_image.shape[1]):
        if depth_image[v, u] == 0:
            continue
        z = distance[v, u]
        x = (u - cx) * z / fx
        y = (v - cy) * z / fy
        point_cloud.points.append([x, y, z])
        point_cloud.colors.append(rgb_image[v, u])
 
# 转换点云到o3d格式
point_cloud.estimate_normals()
 
# 可视化点云
o3d.visualization.draw_geometries([point_cloud])

确保你有相机的内参,这些值取决于你使用的相机型号和相机标定结果。depth.pngrgb.jpg 分别是深度图像和RGB图像的文件名,你需要根据你的文件位置进行相应的更改。

这段代码使用了Open3D库来创建和可视化点云。首先,它读取深度图像并将其转换为距离图,然后遍历深度图像中的每个像素,根据相机的内参计算对应的3D坐标,并将颜色信息从RGB图像中提取并添加到点云中。最后,使用Open3D的 estimate_normals() 函数估算点云的法向量,并使用 draw_geometries() 函数显示点云。

2024-08-25



# 导入需要的库
import re
from itertools import groupby
from difflib import SequenceMatcher
 
# 定义一个函数,用于将语音转换为文本
def speech_to_text(speech):
    # 这里可以添加语音识别的代码
    # 为了示例,我们简单地将语音内容转换为文本
    return speech.replace('语音', '')
 
# 定义一个函数,用于将文本转换为语音
def text_to_speech(text):
    # 这里可以添加文本转语音的代码
    # 为了示例,我们简单地在文本前后添加 '语音' 标签
    return f"语音{text}语音"
 
# 示例使用
speech_content = "语音欢迎来到传奇开心果官方网站语音"
text_content = speech_to_text(speech_content)
print(text_content)  # 输出: 欢迎来到传奇开心果官方网站
speech_content_from_text = text_to_speech(text_content)
print(speech_content_from_text)  # 输出: 语音欢迎来到传奇开心果官方网站语音

这个示例代码展示了如何将语音内容转换为文本,以及如何将文本转换为语音标签包裹的形式。在实际应用中,需要使用真正的语音识别和文本转语音库来替换示例中的简单字符串操作。

2024-08-25

split() 是 Python 中的一个字符串方法,用于将字符串通过指定的分隔符拆分为子字符串列表。

函数原型:




str.split(separator=None, maxsplit=-1)

参数说明:

  • separator(可选):指定用作分隔符的字符串。默认为空白字符,包括空格、换行 \n、制表符 \t 等。
  • maxsplit(可选):指定最大分割次数,超过这个次数后剩余部分将被整体保留作为最后一个元素。默认为 -1,表示分割所有可能的部分。

返回值:

返回一个字符串列表,由原字符串以 separator 为分隔符拆分得到。

示例代码:




text = "hello,world,python"
# 使用默认空白字符作为分隔符
print(text.split())  # 输出: ['hello,world,python']
 
# 使用逗号作为分隔符
print(text.split(',')  # 输出: ['hello', 'world', 'python']
 
# 最大分割次数
print(text.split(',', 1)  # 输出: ['hello', 'world,python']

在实际应用中,split() 方法非常常见,用于解析 CSV 文件内容、处理用户输入等场景。

2024-08-25



import pandas as pd
 
# 读取Excel文件
df = pd.read_excel('example.xlsx')
 
# 按工作表拆分
xls = pd.ExcelFile('example.xlsx')
dfs = {sheet_name: xls.parse(sheet_name) for sheet_name in xls.sheet_names}
 
# 按行拆分
chunks = [df.iloc[i:i+3] for i in range(0, df.shape[0], 3)]
 
# 按列拆分
panels = pd.Panel({i: df.iloc[:, j:j+3] for i in range(df.shape[1])})
 
# 按单元格内容拆分
# 假设我们有一个函数可以根据内容决定如何拆分
def split_by_content(df):
    # 这里是拆分逻辑,例如根据某列的值
    groups = df.groupby(df['ColumnName'])
    return [group for _, group in groups]
 
splitted_df = split_by_content(df)

这段代码展示了如何使用pandas库来读取Excel文件,并且将其按工作表、行、列以及内容进行拆分。其中pd.read_excel用于读取文件,ExcelFileparse方法用于按工作表读取数据,iloc方法用于按行拆分,Panel对象用于按列拆分。split_by_content是一个示例函数,用于展示如何根据内容进行拆分。