AI软件下载
有趣网站推荐及实用软件下载

python变量被传递后值被改变,原来的变量无法多次引用,生成器无法多次迭代

今天在调试一个python应用的时候发现了一个问题,先看代码如下:

segments,_ = model.transcribe(audio_file_name, beam_size=args.beam_size)
    if('txt' in args.output_type):
        outputtxt(args.output_path,bf,segments)
    if('srt' in args.output_type):
        outputsrt(args.output_path,bf,segments) 

segments变量依次为outputtxt,outputsrt两个函数引用,不管是先执行哪个函数,总之后执行的那个函数再使用segments的时候,segments的值被改变了,后来又试了一下

array = copy.deepcopy(array)

仍然没有作用,然后print(f”segments: {segments}”),看到输出如下信息:

segments: <generator object WhisperModel.generate_segments at 0x000001F2F518A3B0>

原来segments是一个生成器,生成器只能被迭代一次,如果在之前的函数中已经迭代过这个生成器,那么后面那个函数再尝试迭代时,它就为空了。所以第二个函数永远无法再引用segments,

解决方法:将segments生成器转换为一个列表,这样就可以多次迭代了,只需要再segments下面添加一行代码即可:

segments = list(segments)

这样下面的多个函数再调用segments的时候,值都是一样的,


AI软件用不了?2元爽玩4090: 立即体验>>

热门大语言模型API免费体验: 立即获取>>

软件催更及1对1人工答疑支持: https://nuowa.net/1806
赞(0) 打赏
软件无法使用?点击查看常见问题说明>>

最近更新

FunASR语音识别转文字软件区分说话人版-诺瓦小站

FunASR语音识别转文字软件区分说话人版

FunASR是一款优秀的基础语音识别框架,配合阿里通义团队开发的其它语音识别模型,能够实现非常好语音转文字效果,尤其在中文语音识别方面,鉴于有些用户需要对语音识别内容区分说话人,我重新做了一版区分说话人的版本。软件支持多语言识别,但是还是尽...

觉得文章对你有帮助就打赏一下作者

非常感谢你的打赏,我将有更多的动力继续提供优质内容,让我们一起创建更加美好的世界!

支付宝扫一扫

微信扫一扫