Google 高级搜索助手

在谷歌搜索页面顶部添加一个高级搜索表单

  1. // ==UserScript==
  2. // @name Advanced Search Assistant for Google
  3. // @name:zh-CN Google 高级搜索助手
  4. // @description:zh-CN 在谷歌搜索页面顶部添加一个高级搜索表单
  5. // @name:ar Google مساعد البحث المتقدم
  6. // @description:ar أضف نموذج بحث متقدم إلى أعلى صفحة بحث Google الخاصة بك
  7. // @name:bg Google Помощник за разширено търсене
  8. // @description:bg Добавете формуляр за разширено търсене в горната част на вашата страница за търсене в Google
  9. // @name:cs Google Pokročilý asistent vyhledávání
  10. // @description:cs Přidejte formulář pro pokročilé vyhledávání do horní části stránky vyhledávání Google
  11. // @name:da Google Avanceret søgeassistent
  12. // @description:da Tilføj en avanceret søgeformular øverst på din Google-søgeside
  13. // @name:de Google Erweiterter Suchassistent
  14. // @description:de Fügen Sie oben auf Ihrer Google-Suchseite ein erweitertes Suchformular hinzu
  15. // @name:el Google Βοηθός σύνθετης αναζήτησης
  16. // @description:el Προσθέστε μια φόρμα σύνθετης αναζήτησης στην κορυφή της σελίδας αναζήτησης Google
  17. // @name:en Google Advanced search assistant
  18. // @description:en Add an advanced search form to the top of your Google search page
  19. // @name:eo Google Altnivela serĉa asistanto
  20. // @description:eo Aldonu altnivelan serĉformularon al la supro de via serĉpaĝo de Guglo
  21. // @name:es Google asistente de búsqueda avanzada
  22. // @description:es Agregue un formulario de búsqueda avanzada en la parte superior de su página de búsqueda de Google
  23. // @name:fi Google Tarkennettu hakuavustaja
  24. // @description:fi Lisää tarkennettu hakulomake Google-hakusivusi yläosaan
  25. // @name:fr Google Assistant de recherche avancée
  26. // @description:fr Ajoutez un formulaire de recherche avancée en haut de votre page de recherche Google
  27. // @name:he Google עוזר חיפוש מתקדם
  28. // @description:he הוסף טופס חיפוש מתקדם לראש דף החיפוש שלך בגוגל
  29. // @name:hr Google Pomoćnik za napredno pretraživanje
  30. // @description:hr Dodajte obrazac za napredno pretraživanje na vrh svoje stranice Google pretraživanja
  31. // @name:hu Google Speciális keresési asszisztens
  32. // @description:hu Adjon hozzá egy speciális keresési űrlapot a Google keresési oldalának tetejére
  33. // @name:id Google Asisten pencarian lanjutan
  34. // @description:id Tambahkan formulir pencarian lanjutan ke bagian atas halaman pencarian Google Anda
  35. // @name:it Google Assistente di ricerca avanzata
  36. // @description:it Aggiungi un modulo di ricerca avanzata nella parte superiore della pagina di ricerca di Google
  37. // @name:ja Google 高度な検索アシスタント
  38. // @description:ja Google 検索ページの上部に高度な検索フォームを追加します
  39. // @name:ka Google გაფართოებული საძიებო ასისტენტი
  40. // @description:ka დაამატეთ გაფართოებული საძიებო ფორმა თქვენი Google ძიების გვერდის ზედა ნაწილში
  41. // @name:ko Google 고급 검색 도우미
  42. // @description:ko Google 검색 페이지 상단에 고급 검색 양식을 추가하세요.
  43. // @name:nl Google Geavanceerde zoekassistent
  44. // @description:nl Voeg een geavanceerd zoekformulier toe bovenaan uw Google-zoekpagina
  45. // @name:nb Google Avansert søkeassistent
  46. // @description:nb Legg til et avansert søkeskjema øverst på Google-søkesiden din
  47. // @name:pl Google Zaawansowany asystent wyszukiwania
  48. // @description:pl Dodaj formularz wyszukiwania zaawansowanego na górze strony wyszukiwania Google
  49. // @name:pt-BR Google Assistente de pesquisa avançada
  50. // @description:pt-BR Adicione um formulário de pesquisa avançada ao topo da sua página de pesquisa do Google
  51. // @name:ro Google Asistent de căutare avansată
  52. // @description:ro Adăugați un formular de căutare avansată în partea de sus a paginii dvs. de căutare Google
  53. // @name:ru Google Расширенный помощник поиска
  54. // @description:ru Добавьте форму расширенного поиска в верхнюю часть страницы поиска Google.
  55. // @name:sk Google Pokročilý asistent vyhľadávania
  56. // @description:sk Pridajte formulár rozšíreného vyhľadávania do hornej časti stránky vyhľadávania Google
  57. // @name:sr Google Помоћник за напредну претрагу
  58. // @description:sr Додајте образац за напредну претрагу на врх ваше странице Гоогле претраге
  59. // @name:sv Google Avancerad sökassistent
  60. // @description:sv Lägg till ett avancerat sökformulär överst på din Google-söksida
  61. // @name:th Google ผู้ช่วยการค้นหาขั้นสูง
  62. // @description:th เพิ่มแบบฟอร์มการค้นหาขั้นสูงที่ด้านบนของหน้าการค้นหาของ Google
  63. // @name:tr Google Gelişmiş arama asistanı
  64. // @description:tr Google arama sayfanızın üst kısmına gelişmiş bir arama formu ekleyin
  65. // @name:ug Google ئىلغار ئىزدەش ياردەمچىسى
  66. // @description:ug Google ئىزدەش بېتىڭىزنىڭ ئۈستىگە ئىلغار ئىزدەش جەدۋىلىنى قوشۇڭ
  67. // @name:uk Google Розширений пошуковий помічник
  68. // @description:uk Додайте форму розширеного пошуку у верхній частині сторінки пошуку Google
  69. // @name:vi Google Trợ lý tìm kiếm nâng cao
  70. // @description:vi Thêm biểu mẫu tìm kiếm nâng cao vào đầu trang tìm kiếm Google của bạn
  71. // @name:zh-TW Google 高級搜尋助手
  72. // @description:zh-TW 在谷歌搜尋頁面頂部新增一個高級搜尋表單
  73. // @name:zh-HK Google 高級搜尋助手
  74. // @description:zh-HK 在谷歌搜尋頁面頂部新增一個高級搜尋表單
  75. // @name:fr-CA Google Assistant de recherche avancée
  76. // @description:fr-CA Ajoutez un formulaire de recherche avancée en haut de votre page de recherche Google
  77. // @namespace https://github.com/ChinaGodMan/UserScripts
  78. // @version 0.1.9.45
  79. // @description Add an advanced search form to the top of the page
  80. // @author shiquda &人民的勤务员 <china.qinwuyuan@gmail.com>
  81. // @match *://www.google.com/search*
  82. // @include *://*google*/search*
  83. // @grant GM_addStyle
  84. // @grant GM_setValue
  85. // @grant GM_getValue
  86. // @license MIT
  87. // @icon 
  88. // @iconbak https://github.com/ChinaGodMan/UserScripts/raw/main/docs/icon/Scripts%20Icons/Google-advance-search.png
  89. // @supportURL https://github.com/ChinaGodMan/UserScripts/issues
  90. // @homepageURL https://github.com/ChinaGodMan/UserScripts
  91. // ==/UserScript==
  92.  
  93. (function () {
  94. 'use strict'
  95. let isMobile = false
  96. if (
  97. navigator.userAgent.match(/Android/i) ||
  98. navigator.userAgent.match(/webOS/i) ||
  99. navigator.userAgent.match(/iPhone/i) ||
  100. navigator.userAgent.match(/iPad/i) ||
  101. navigator.userAgent.match(/iPod/i) ||
  102. navigator.userAgent.match(/BlackBerry/i) ||
  103. navigator.userAgent.match(/Windows Phone/i)
  104. ) {
  105. // On mobile device
  106. isMobile = true
  107. }
  108.  
  109. let isDarkMode = false
  110.  
  111. try {
  112. if (
  113. window.matchMedia &&
  114. window.matchMedia('(prefers-color-scheme: dark)').matches
  115. ) {
  116. // Dark mode is enabled
  117. isDarkMode = true
  118. console.log('Dark mode is enabled.')
  119. }
  120. } catch (error) {
  121. console.log('Failed to determine the color mode.', error)
  122. }
  123.  
  124. const userLanguage = '' // You can set your language config here manually. 'zh-CN' & 'en' are supported now.
  125.  
  126. const supportedLanguages = ['zh-CN', 'en']
  127.  
  128. const translation = {
  129. as_q: {
  130. 'zh-CN': '搜索字词:',
  131. en: 'Search word:'
  132. },
  133. as_epq: {
  134. 'zh-CN': '与以下字词完全匹配:',
  135. en: 'Match the following words exactly:'
  136. },
  137. as_oq: {
  138. 'zh-CN': '包含以下任意字词:',
  139. en: 'Contains any of the following words:'
  140. },
  141. as_eq: {
  142. 'zh-CN': '排除以下字词:',
  143. en: 'Exclude the following words:'
  144. },
  145. as_nlo: {
  146. 'zh-CN': '包含的数字范围:从',
  147. en: 'Number range: from'
  148. },
  149. as_nhi: {
  150. 'zh-CN': '到:',
  151. en: 'to:'
  152. },
  153. lr: {
  154. 'zh-CN': '语言:',
  155. en: 'Language:'
  156. },
  157. cr: {
  158. 'zh-CN': '地区:',
  159. en: 'Region:'
  160. },
  161. as_qdr: {
  162. 'zh-CN': '最后更新时间:',
  163. en: 'Last update time:'
  164. },
  165. as_sitesearch: {
  166. 'zh-CN': '网站或域名:',
  167. en: 'Website or domain:'
  168. },
  169. as_occt: {
  170. 'zh-CN': '字词出现位置:',
  171. en: 'Word position:'
  172. },
  173. as_filetype: {
  174. 'zh-CN': '文件类型:',
  175. en: 'File type:'
  176. },
  177. tbs: {
  178. 'zh-CN': '使用权限:',
  179. en: 'Usage rights:'
  180. },
  181. advancedSearch: {
  182. 'zh-CN': '高级搜索',
  183. en: 'Advanced Search'
  184. },
  185. search: {
  186. 'zh-CN': '搜索',
  187. en: 'Search'
  188. },
  189. clear: {
  190. 'zh-CN': '清空',
  191. en: 'Clear'
  192. },
  193. as_qdr_select: {
  194. '': {
  195. 'zh-CN': '请选择',
  196. en: 'Please select'
  197. },
  198. d: {
  199. 'zh-CN': '一天内',
  200. en: 'Past 24 hours'
  201. },
  202. w: {
  203. 'zh-CN': '一周内',
  204. en: 'Past week'
  205. },
  206. m: {
  207. 'zh-CN': '一月内',
  208. en: 'Past month'
  209. },
  210. y: {
  211. 'zh-CN': '一年内',
  212. en: 'Past year'
  213. }
  214. },
  215. as_occt_select: {
  216. '': {
  217. 'zh-CN': '请选择',
  218. en: 'Please select'
  219. },
  220. title: {
  221. 'zh-CN': '网页标题中',
  222. en: 'In the title of the web page'
  223. },
  224. body: {
  225. 'zh-CN': '网页正文中',
  226. en: 'In the body of the web page'
  227. },
  228. url: {
  229. 'zh-CN': '网页网址中',
  230. en: 'In the URL of the web page'
  231. },
  232. links: {
  233. 'zh-CN': '指向网页的链接中',
  234. en: 'In the links to the web page'
  235. }
  236. }
  237. }
  238. const style = `
  239. #advancedSearchToggleButton {
  240. margin-right: 10px;
  241. border: none;
  242. border-radius: 5px;
  243. background-color: #007bff;
  244. color: #fff;
  245. font-size: 14px;
  246. font-weight: bold;
  247. margin: 10px;
  248. }
  249.  
  250.  
  251. #advancedSearchFormContainer {
  252. position: fixed;
  253. ${isMobile ? 'top: 150px;' : 'top: 130px;'}
  254. ${isMobile ? 'left: 15px;' : 'left: 30px;'}
  255. display: none;
  256. padding: 10px;
  257. border: 1px solid #ccc;
  258. border-radius: 5px;
  259. font-size: 14px;
  260. font-weight: bold;
  261. ${isDarkMode
  262. ? 'background-color: rgba(0, 0, 0, 1);'
  263. : 'background-color: rgba(255, 255, 255, 1);'
  264. }
  265. ${isMobile ? 'column-count: 2;' : ''} /* 在移动设备上分为两列 */
  266. z-index: 1000; // Make sure the button is on top of the search bar
  267. }
  268.  
  269.  
  270. #advancedSearchFormContainer label {
  271. display: block;
  272. margin-top: 5px;
  273. }
  274.  
  275.  
  276. #advancedSearchFormContainer input[type="text"] {
  277. margin-top: 5px;
  278. padding: 5px;
  279. border: 1px solid #ccc;
  280. border-radius: 5px;
  281. }
  282.  
  283. #advancedSearchFormContainer select {
  284. margin-top: 5px;
  285. padding: 5px;
  286. border-radius: 5px;
  287. }
  288.  
  289. #advancedSearchFormContainer button {
  290. border: none;
  291. border-radius: 5px;
  292. background-color: #007bff;
  293. color: #fff;
  294. font-size: 14px;
  295. font-weight: bold;
  296. margin: 20px;
  297. }
  298. `
  299. GM_addStyle(style)
  300.  
  301. let language = 'en'
  302. if (userLanguage.length > 0) { // userLanguage is set manually
  303. if (supportedLanguages.includes(userLanguage)) {
  304. language = userLanguage
  305. } else {
  306. console.log(`Unsupported language: ${userLanguage}`)
  307. }
  308. } else {
  309. // Check if any of the user's preferred languages are supported
  310. language =
  311. navigator.languages
  312. .map((lang) => lang.split('-')[0]) // Consider only the language part, not the region
  313. .map((lang) => supportedLanguages.find((supportedLang) => supportedLang.split('-')[0] === lang)) // Match with the supported languages
  314. .filter(Boolean) // Remove undefined values
  315. .shift() // Take the first matched language
  316. || 'en' // Default to 'en' if no match found
  317. console.log(`Here is the language: ${language}`)
  318. }
  319.  
  320. // Create user interface
  321. const toggleButton = document.createElement('button')
  322. toggleButton.className = 'nfSF8e'
  323. toggleButton.textContent = translation['advancedSearch'][language]
  324. toggleButton.id = 'advancedSearchToggleButton'
  325. if (isMobile) {
  326. document.querySelector('.Fh5muf').appendChild(toggleButton)
  327. } else {
  328. document.querySelector('.logo').appendChild(toggleButton)
  329. const searchContainer = document.querySelector('.RNNXgb')
  330. searchContainer.appendChild(toggleButton)
  331. }
  332.  
  333.  
  334.  
  335. // Add minimal style for positioning
  336. toggleButton.style.marginTop = '5px' // Add some space above the button
  337. toggleButton.style.marginLeft = '5px' // Add some space to the left of the button
  338. // Add any additional styles to match the search bar's height or other styling
  339.  
  340. const formContainer = document.createElement('div')
  341. formContainer.id = 'advancedSearchFormContainer'
  342. document.body.appendChild(formContainer)
  343.  
  344. //
  345. const form = document.createElement('form')
  346. formContainer.appendChild(form)
  347.  
  348. const params = {
  349. as_q: translation['as_q'][language],
  350. as_epq: translation['as_epq'][language],
  351. as_oq: translation['as_oq'][language],
  352. as_eq: translation['as_eq'][language],
  353. as_nlo: translation['as_nlo'][language],
  354. as_nhi: translation['as_nhi'][language],
  355. // 'lr': translation['lr'][language],
  356. // 'cr': translation['cr'][language],
  357. as_qdr: {
  358. name: translation['as_qdr'][language],
  359. options: {
  360. '': translation['as_qdr_select'][''][language],
  361. d: translation['as_qdr_select']['d'][language],
  362. w: translation['as_qdr_select']['w'][language],
  363. m: translation['as_qdr_select']['m'][language],
  364. y: translation['as_qdr_select']['y'][language]
  365. }
  366. },
  367. as_sitesearch: translation['as_sitesearch'][language],
  368. as_occt: {
  369. name: translation['as_occt'][language],
  370. options: {
  371. '': translation['as_occt_select'][''][language],
  372. title: translation['as_occt_select']['title'][language],
  373. body: translation['as_occt_select']['body'][language],
  374. url: translation['as_occt_select']['url'][language],
  375. links: translation['as_occt_select']['links'][language]
  376. }
  377. },
  378. as_filetype: translation['as_filetype'][language]
  379. // 'tbs': translation['tbs'][language],
  380. }
  381.  
  382. for (const param in params) {
  383. if (typeof params[param] === 'object') {
  384. const label = document.createElement('label')
  385. label.textContent = params[param].name
  386. const select = document.createElement('select')
  387. select.name = param
  388.  
  389. Object.keys(params[param]['options']).forEach((option) => {
  390. const optionElement = document.createElement('option')
  391. optionElement.value = option
  392. optionElement.textContent = params[param]['options'][option]
  393. select.appendChild(optionElement)
  394. })
  395.  
  396. form.appendChild(label)
  397. form.appendChild(select)
  398. form.appendChild(document.createElement('br'))
  399. continue
  400. }
  401. const label = document.createElement('label')
  402. label.textContent = params[param]
  403. const input = document.createElement('input')
  404. input.name = param
  405. input.type = 'text'
  406. form.appendChild(label)
  407. form.appendChild(input)
  408. form.appendChild(document.createElement('br'))
  409. }
  410.  
  411. const searchButton = document.createElement('button')
  412. searchButton.textContent = translation['search'][language]
  413. form.appendChild(searchButton)
  414.  
  415. // Add a clear button to reset the form
  416. const clearButton = document.createElement('button')
  417. clearButton.textContent = translation['clear'][language]
  418. clearButton.addEventListener('click', function (event) {
  419. event.preventDefault()
  420. form.reset()
  421. })
  422. form.appendChild(clearButton)
  423.  
  424. // Load saved data and fill the form when opening a new page
  425. window.addEventListener('load', function () {
  426. for (const param in params) {
  427. const savedValue = GM_getValue(param)
  428. if (savedValue) {
  429. form[param].value = savedValue
  430. }
  431. }
  432. })
  433.  
  434. // Save form data to Greasemonkey storage
  435. form.addEventListener('input', function () {
  436. for (const param in params) {
  437. GM_setValue(param, form[param].value)
  438. }
  439. })
  440.  
  441. // Toggle the form display
  442. toggleButton.addEventListener('click', function (event) {
  443. event.preventDefault()
  444. let status = formContainer.style.display
  445. status = status === 'none' || status === '' ? 'block' : 'none'
  446. formContainer.style.display = status
  447. })
  448.  
  449. // Submit the form
  450. form.addEventListener('submit', function (event) {
  451. event.preventDefault()
  452. const searchParams = new URLSearchParams()
  453. for (const param in params) {
  454. const value = form[param].value
  455. if (value) {
  456. searchParams.set(param, value)
  457. }
  458. }
  459. const searchUrl =
  460. 'https://www.google.com/search?' + searchParams.toString()
  461. window.location.href = searchUrl
  462. })
  463. })()

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址