我曾经在 Firefox 上使用 python 命令执行此操作,但最近发生了一些变化,我无法再获取 URL 了!
以前在 firefox 上运行的内容:
#!/bin/bash current_tab_num () { python2 <<< $'import json\nf = open("/home/username/.mozilla/firefox/xxxxx.default/sessionstore.js", "r")\njdata = json.loads(f.read())\nf.close()\nprint str(jdata["windows"][0]["selected"])' } current_tab_url () { sed -n "$(current_tab_num)p" <(python2 <<< $'import json\nf = open("/home/username/.mozilla/firefox/xxxxx.default/sessionstore.js", "r")\njdata = json.loads(f.read())\nf.close()\nfor win in jdata.get("windows"):\n\tfor tab in win.get("tabs"):\n\t\ti = tab.get("index") - 1\n\t\tprint tab.get("entries")[i].get("url")') } current_tab_url
谁能告诉我如何在 Firefox 和/或 chrome 中执行此操作?
笔记:我不懂 python,我只是在某处找到这些命令并在 bash 中使用它们!
答案1
我遇到了同样的问题,并在尝试解决它时解决了这个问题,所以我将在这里发布我的解决方案(这非常糟糕)。
我使用 wmctrl (您可以使用 xprop 代替)和 xdotool 来执行此操作。以前,我使用扩展程序使 URL 在标题栏中可见(然后您可以通过 xprop 或 wmctrl 访问该 url)。这两种方法都工作得很好,尽管它并不是真正的“干净”。
id=$(wmctrl -l | grep -oP "(?<=)(0x\w+)(?=.*Chromium)") //Put here the regex for the browser you use
xdotool key --window $id "ctrl+l"
xdotool key --window $id "ctrl+c"
现在您的剪贴板中已包含该网址。然后我使用 xclip 来处理该 URL。
如果有人找到的话,我很想看到一个真正的解决方案。
答案2
您能否说出执行后出现的错误,因为该脚本正在为我工作。这里有同样的问题,使用php
and回答perl
:
由于主要部分是Python,所以这里是一个纯粹的Python脚本,要做同样的事情,也尝试一下:
#!/usr/bin/python
import json
f = open("recovery.js","r")
jdata = json.loads(f.read())
f.close()
number_of_selected_tab = jdata["windows"][0]["selected"]
tab_number = 1
for win in jdata.get("windows"):
for tab in win.get("tabs"):
if number_of_selected_tab == tab_number :
tab_index = tab.get("index") - 1
print tab.get("entries")[tab_index].get("url")
tab_number = tab_number + 1
我将/home/username/.mozilla/firefox/xxxxx.default/sessionstore.js
文件替换为recovery.js
.就我而言(Mozilla Firefox 44.0、openSUSE 13.1),文件是~/.mozilla/firefox/*.default/sessionstore-backups/recovery.js
.最后但并非最不重要的一点是,如果您有两个正在运行的实例,则脚本将不起作用Firefox
。