headless=true的模式下是无法播放声音的,只有设置false才能实现
两种方式
1、可以通过修改浏览器启动参数来允许自动播放声音:
from playwright.sync_api import sync_playwright
with sync_playwright() as p:
# 配置浏览器参数以允许自动播放
browser = p.chromium.launch(
args=[
'--autoplay-policy=no-user-gesture-required', # 允许自动播放
'--disable-features=PreloadMediaEngagementData,AutoplayIgnoreWebAudio' # 禁用相关限制
],
headless=False # 非无头模式,便于测试
)
page = browser.new_page()
page.goto('https://example.com') # 替换为你要测试的网站
# 等待音频元素加载完成
page.wait_for_selector('audio')
# 点击页面以触发用户交互(有些网站可能仍然需要)
page.click('body')
# 等待一段时间以观察效果
page.wait_for_timeout(10000)
browser.close()
2、使用 JavaScript 执行播放from playwright.sync_api import sync_playwright
with sync_playwright() as p:
browser = p.chromium.launch(headless=False)
page = browser.new_page()
page.goto('https://example.com') # 替换为包含音频的网站
# 等待音频元素加载
audio_selector = 'audio'
page.wait_for_selector(audio_selector)
# 执行JavaScript播放音频
page.evaluate('''() => {
const audioElements = document.querySelectorAll('audio');
audioElements.forEach(audio => {
audio.play().catch(e => console.log('播放失败:', e));
});
}''')
# 等待一段时间以观察效果
page.wait_for_timeout(10000)
browser.close()
网友回复
有没有不依赖embedding向量的RAG技术?
有没有支持实时打断语音通话并后台帮你执行任何的ai模型?
开源ai大模型文件格式GGUF、MLX、Safetensors、 ONNX 有什么区别?
出海挣钱支付收款PayPal、Wise 、PingPong、Stripe如何选择?
如何实现类似google的图片隐形水印添加和识别技术?
linux上如何运行任意windows程序?
ai能写出比黑客还厉害的零日漏洞等攻击工具攻击任意软件系统工程?
js如何获取浏览器的音频上下文指纹、Canvas指纹、WebGL渲染特征?
为啥ai开始抛弃markdown文本,重新偏好html文本了?
网站有没有办法鉴别访问请求是由ai操控chrome-devtools-mcp发出的?


