• win录制内部声音


    import wave
    import threading
    from os import remove, mkdir, listdir
    from os.path import exists, splitext, basename, join
    from datetime import datetime
    from time import sleep
    from shutil import rmtree
    import pyaudio
    from PIL import ImageGrab
    from moviepy.editor import *
    
    CHUNK_SIZE = 1024
    CHANNELS = 2
    FORMAT = pyaudio.paInt16
    RATE = 48000
    allowRecording = True
    
    def findInternalRecordingDevice(self,p):
    	#要找查的设备名称中的关键字
    	target = '立体声混音'
    	#逐一查找声音设备  
    	for i in range(p.get_device_count()):
    		devInfo = p.get_device_info_by_index(i)   
    		if devInfo['name'].find(target)>=0 and devInfo['hostApi'] == 0 :      
    			#print('已找到内录设备,序号是 ',i)
    			return i
    	print('无法找到内录设备!')
    	return -1
    
    def record_audio():
    	p = pyaudio.PyAudio()
    	# 创建输入流
    	dev_idx = findInternalRecordingDevice(p)
    	if dev_idx < 0 :            
    		return
    	stream = p.open(input_device_index=dev_idx,format=FORMAT, channels=CHANNELS,
    					rate=RATE, input=True,
    					frames_per_buffer=CHUNK_SIZE)
    	wf = wave.open(audio_filename, 'wb')
    	wf.setnchannels(CHANNELS)
    	wf.setsampwidth(p.get_sample_size(FORMAT))
    	wf.setframerate(RATE)
    	while allowRecording:
    		# 从录音设备读取数据,直接写入wav文件
    		data = stream.read(CHUNK_SIZE)
    		wf.writeframes(data)
    	wf.close()
    	stream.stop_stream()
    	stream.close()
    	p.terminate()
    
    
    def record_screen():
    	index = 1
    	while allowRecording:
    		ImageGrab.grab().save(f'{pic_dir}{index}.jpg',
    							quality=95, subsampling=0)
    		sleep(0.04)
    		index = index + 1
    
    
    audio_filename = str(datetime.now())[:19].replace(':', '_') + '.mp3'
    pic_dir = 'pics'
    if not exists(pic_dir):
    	mkdir(pic_dir)
    # video_filename = audio_filename[:-3] + 'avi'
    video_filename = audio_filename[:-3] + 'mp4'
    # 创建两个线程,分别录音和录屏
    t1 = threading.Timer(3, record_audio)
    t2 = threading.Timer(3, record_screen)
    t1.start()
    t2.start()
    print('3秒后开始录制,按q键结束录制')
    while (ch := input()) != 'q':
    	pass
    allowRecording = False
    t1.join()
    t2.join()
    
    # 把录制的音频和屏幕截图合成为视频文件
    audio = AudioFileClip(audio_filename)
    pic_files = [join(pic_dir, fn) for fn in listdir(pic_dir)
    			if fn.endswith('.jpg')]
    # 按文件名编号升序排序
    pic_files.sort(key=lambda fn: int(splitext(basename(fn))[0]))
    # 计算每个图片的显示时长
    each_duration = round(audio.duration / len(pic_files), 4)
    # 连接多个图片
    image_clips = []
    for pic in pic_files:
    	image_clips.append(ImageClip(pic,
    								duration=each_duration))
    video = concatenate_videoclips(image_clips)
    video = video.set_audio(audio)
    video.write_videofile(video_filename, codec='mpeg4', fps=25)
    # 删除临时音频文件和截图
    remove(audio_filename)
    rmtree(pic_dir)
    
  • 相关阅读:
    在vue项目中使用codemirror插件实现代码编辑器功能(代码高亮显示及自动提示)
    解决request.getSession().getServletContext().getRealPath("/")为null问题
    redis数据类型为key的常用命令
    spring boot知识清单
    java 百度地图判断两点距离2
    java 百度地图判断两点距离1
    百度地图js判断点是否在圆形区域内
    百度地图java 判断当前位置是否在多边形区域内
    redis学习之路
    burpsuite插件使用
  • 原文地址:https://www.cnblogs.com/bear-king/p/15132537.html
Copyright © 2020-2023  润新知