-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathscielo_v2.py
80 lines (77 loc) · 3.54 KB
/
scielo_v2.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
from revistas import revistas
from reports import report_scrape
import time, os
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.firefox.options import Options
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
timestr = time.strftime("%Y-%m-%d")
saveMode = ''
def main():
global saveMode
while (saveMode != 1 and saveMode != 2):
url = 'https://www.scielo.br//journals/thematic?status=current'
# Definição da área do conhecimento para raspagem
print('-=-Definição da área temática-=-\n')
area = str(input(
'- Opções:\n'
'1- Ciências Agrárias\n'
'2- Ciências Biológicas\n'
'3- Ciências da Saúde\n'
'4- Ciências Exatas e da Terra\n'
'5- Ciências Humanas\n'
'6- Ciências Sociais Aplicadas\n'
'7- Engenharias\n'
'8- Linguística, Letras e Artes\n'
'Digite o número correspondente à área temática que deseja raspar: \n'))
print('-='*50)
saveMode = int(input('-=-Definição do tipo de raspagem-=-\n'
'1- Salvar os XMLs;\n'
'2- Salvar os XMLs e baixar os PDFs.\n'
'Tipo de Raspagem (1 ou 2): '))
diretorio = os.path.join('scielo',timestr)
if not os.path.exists(diretorio):
#Se a pasta ainda não existir, cria a pasta
os.makedirs(diretorio)
# Definição das opções do driver
firefox_options = Options()
firefox_options.add_argument('-lang=pt-BR')
firefox_options.add_argument("--headless")
firefox_options.add_argument("--no-sandbox")
firefox_options.add_argument("--start-maximized")
driver = webdriver.Firefox(options=firefox_options)
driver.get(url)
#botão de aceitar cookies
try:
cookies = driver.find_element(By.CLASS_NAME,'alert-cookie-notification')
#Clicando para fechar o aviso
WebDriverWait(driver, 10).until(EC.element_to_be_clickable(
(By.XPATH, '/html/body/div[6]/a[2]')
)).click()
except:
pass
# set locale for pt: find element by xpath and try to find element by class name
locale_div = driver.find_element(By.XPATH, '/html/body/header/div/div/div[3]')
# try to find element by class name and click it if found
try:
local_pt = locale_div.find_element(By.CLASS_NAME, 'lang-pt').click()
except:
pass
journal_table = driver.find_element(By.ID,'journals_table_body')
tematica = journal_table.find_element(By.ID,f"heading-{area}")
print(f'\n-=-{tematica.text}-=-')
btn = tematica.find_element(By.TAG_NAME,'a').click()
time.sleep(1)
area_box = driver.find_element(By.ID,f'collapseContent-{area}')
journal_list = area_box.find_elements(By.CLASS_NAME,'collectionLink ')
report_scrape(diretorio, timestr, area, saveMode)
for journal in journal_list:
link = journal.get_attribute("href")
link_final = link+'grid'
#Função para acessar o grid
name = journal.find_element(By.CLASS_NAME,"journalTitle").text
revistas(diretorio, link, link_final, name, saveMode)
print('fim da raspagem')
if __name__ == "__main__":
main()