Два возможных подхода:
Вы можете добавить временную метку к вашему имени файла, так что вы будете создавать разные CSV-файлы для каждого запуска вашего скрипта
from datetime import datetime
timestamp = datetime.now().strftime("%Y-%m-%d %H.%m.%s")
df.to_csv(rf'Uljanas-MacBook-Air-2:~ uljanadufour$\{timestamp} bayern-munich123.csv')
Что даст вам файлы в формате:
"2019-05-08 10.39.05 bayern-munich123.csv"
Используя формат день-месяц-год, ваши файлы будут автоматически отсортированы в хронологическом порядке.
В качестве альтернативы вы могли быиспользуйте режим добавления, чтобы добавить к существующему файлу CSV:
df.to_csv(r'Uljanas-MacBook-Air-2:~ uljanadufour$\bayern-munich123.csv', mode='a')
Наконец, ваш текущий код сохраняет только последний URL, если вы хотите сохранить каждый URL как отдельный файл, вам нужно будет сделать отступ для последних двух строк внутри цикла.Вы можете добавить число к имени файла, чтобы различать каждый из URL, например, 1
или 2
следующим образом.Функцию Python enumerate()
можно использовать, чтобы дать вам номер для каждого URL:
from datetime import datetime
from bs4 import BeautifulSoup as bs
import requests
import re
import pandas as pd
import itertools
headers = {'User-Agent' : 'Mozilla/5.0'}
df_headers = ['position_number' , 'position_description' , 'name' , 'dob' , 'nationality' , 'height' , 'foot' , 'joined' , 'signed_from' , 'contract_until']
urls = [
'https://www.transfermarkt.com/fc-bayern-munich-u17/kader/verein/21058/saison_id/2018/plus/1',
'https://www.transfermarkt.com/fc-hennef-05-u17/kader/verein/48776/saison_id/2018/plus/1'
]
for index, url in enumerate(urls, start=1):
r = requests.get(url, headers=headers)
soup = bs(r.content, 'html.parser')
position_number = [item.text for item in soup.select('.items .rn_nummer')]
position_description = [item.text for item in soup.select('.items td:not([class])')]
name = [item.text for item in soup.select('.hide-for-small .spielprofil_tooltip')]
dob = [item.text for item in soup.select('.zentriert:nth-of-type(3):not([id])')]
nationality = ['/'.join([i['title'] for i in item.select('[title]')]) for item in soup.select('.zentriert:nth-of-type(4):not([id])')]
height = [item.text for item in soup.select('.zentriert:nth-of-type(5):not([id])')]
foot = [item.text for item in soup.select('.zentriert:nth-of-type(6):not([id])')]
joined = [item.text for item in soup.select('.zentriert:nth-of-type(7):not([id])')]
signed_from = ['/'.join([item.find('img')['title'].lstrip(': '), item.find('img')['alt']]) if item.find('a') else ''
for item in soup.select('.zentriert:nth-of-type(8):not([id])')]
contract_until = [item.text for item in soup.select('.zentriert:nth-of-type(9):not([id])')]
df = pd.DataFrame(list(zip(position_number, position_description, name, dob, nationality, height, foot, joined, signed_from, contract_until)), columns = df_headers)
timestamp = datetime.now().strftime("%Y-%m-%d %H.%M.%S")
df.to_csv(rf'{timestamp} bayern-munich123_{index}.csv')
Затем вы получите имена файлов, такие как:
"2019-05-08 11.44.38 bayern-munich123_1.csv"