python同时播放多首音乐(多进程)

使用multiprocessing创建多个进程达到同时播放音乐的目的,使用多线程则会出现:创建新的线程的时候卡顿。
于此同时multiprocessing可以直接对进程进行控制,可以直接杀死进程!

import contextlib
import multiprocessing
import time
import wave
import eyed3


def get_duration(file_path):
    """
    获取音乐时长
    :param file_path: 文件路径
    :return:
    """
    if file_path.split('.')[-1] == "mp3":
        duration = eyed3.load(file_path).info.time_secs
    elif file_path.split('.')[-1] == "wav":
        with contextlib.closing(wave.open(file_path, 'r')) as f:
            frames = f.getnframes()
            rate = f.getframerate()
            duration = frames / float(rate)
    else:
        raise Exception("必须为MP3或者wav格式")
    return duration


def play(filepath,start_time=0, loop=1):
    import pygame
    pygame.mixer.init()
    print("开始播放音乐", filepath)
    try:
        # 算出播放的时长
        if loop == -1:
            # 如果时间循环为无限长
            length = 1000000  # 辣么设置时长为这么长
        else:
            length = get_duration(filepath) * loop - start_time + 1
        # s = pygame.mixer.Sound(filepath)
        pygame.mixer.music.load(filepath)
        pygame.mixer.music.play(start=start_time, loops=loop)
        # s.play(start_time)

        time.sleep(length)  # 程序休眠
        print("播放结束", filepath)
    except FileNotFoundError:
        print("文件未找到")


if __name__ == '__main__':
    # 记得加上’r‘才不会转义,当然如果啥都不知道,就直接加上就好了
    path = r"C:\Users\asked\Desktop\1\sketch_220405b\data\1.mp3"
    start_time = 10.7  # 从10.7秒开始播放
    music1 = multiprocessing.Process(target=play, args=(path, start_time))
    music1.start()

    # 需要跟文件python同个目录 可以用相对路径 ../music.mp3
    path2 = r"groove.mp3"
    # 重复2次
    loop = 2  # -1 是无限循环
    music2 = multiprocessing.Process(target=play, args=(path2, 0, loop))
    music2.start()
    # 程序暂停5秒后
    time.sleep(5)
    # 停止音乐1
    music1.kill()

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python中,我们可以同时使用多线程和多进程来实现并行处理任务。 多线程和多进程都是实现并行计算的方式,但它们的实现方式不同。多线程是在同一进程内创建多个线程,每个线程独立运行,但它们共享进程的资源。多进程是创建多个独立的进程,每个进程拥有自己的资源,它们之间通过进程间通信(IPC)进行数据交换。 在Python中,我们可以使用`multiprocessing`模块来创建多进程,使用`threading`模块来创建多线程。同时使用多线程和多进程可以充分利用CPU资源,提高程序的运行效率。 以下是一个示例代码,同时使用多线程和多进程来处理数据: ```python import multiprocessing import threading def process_data(data): # 进程处理数据 pass def thread_data(data): # 线程处理数据 pass if __name__ == '__main__': # 创建进程 process1 = multiprocessing.Process(target=process_data, args=(data,)) process2 = multiprocessing.Process(target=process_data, args=(data,)) # 启动进程 process1.start() process2.start() # 创建线程 thread1 = threading.Thread(target=thread_data, args=(data,)) thread2 = threading.Thread(target=thread_data, args=(data,)) # 启动线程 thread1.start() thread2.start() ``` 在上面的示例代码中,我们创建了两个进程和两个线程来处理数据。在实际应用中,我们需要根据具体情况选择使用多线程、多进程或者两者结合使用,以达到最优的效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值