add alternative album detection method
This commit is contained in:
parent
d4ccb41741
commit
41dc8def0e
33
imgin/get.py
33
imgin/get.py
@ -25,7 +25,7 @@ def error(msg):
|
|||||||
def get(url: str, write_dir: str, delete=True):
|
def get(url: str, write_dir: str, delete=True):
|
||||||
orig_url = url
|
orig_url = url
|
||||||
if not url.startswith('https://imgur.com/'):
|
if not url.startswith('https://imgur.com/'):
|
||||||
url = 'https://imgur.com/' + url
|
url = 'https://imgur.com' + url
|
||||||
found_url = ''
|
found_url = ''
|
||||||
found_urls = []
|
found_urls = []
|
||||||
found_list_file = ''
|
found_list_file = ''
|
||||||
@ -47,7 +47,7 @@ def get(url: str, write_dir: str, delete=True):
|
|||||||
if delete:
|
if delete:
|
||||||
Thread(target=delete_file, args=[f"{write_dir}/{url[-11:]}"]).start()
|
Thread(target=delete_file, args=[f"{write_dir}/{url[-11:]}"]).start()
|
||||||
else:
|
else:
|
||||||
print('Detecting album/gallery images', url)
|
print('Detecting album/gallery images (contentUrl)', url)
|
||||||
soup = bs4.BeautifulSoup(requests.get(url).text, 'html.parser')
|
soup = bs4.BeautifulSoup(requests.get(url).text, 'html.parser')
|
||||||
for count, el in enumerate(soup.select('.post-image meta[itemprop="contentUrl"]'), start=1):
|
for count, el in enumerate(soup.select('.post-image meta[itemprop="contentUrl"]'), start=1):
|
||||||
try:
|
try:
|
||||||
@ -55,23 +55,34 @@ def get(url: str, write_dir: str, delete=True):
|
|||||||
if '?1' in found_url:
|
if '?1' in found_url:
|
||||||
continue
|
continue
|
||||||
except KeyError:
|
except KeyError:
|
||||||
error("Could not obtain url for detected image")
|
error("Could not obtain url for detected image (contentUrl)")
|
||||||
continue
|
continue
|
||||||
if found_url.endswith('ico.jpg'):
|
if found_url.endswith('ico.jpg'):
|
||||||
continue
|
continue
|
||||||
found_urls.append(found_url[-11:])
|
found_urls.append(found_url[-11:])
|
||||||
print(f"Downloading image {count}: {found_url}")
|
write(count, found_url, write_dir, delete)
|
||||||
|
if len(found_urls) == 0:
|
||||||
print("Writing image", f"{write_dir}{found_url[-11:]}")
|
print('Detecting album/gallery images (id)', url)
|
||||||
with open(f"{write_dir}{found_url[-11:]}", "wb") as f:
|
for count, el in enumerate(soup.select('.post-image-container'), start=1):
|
||||||
f.write(requests.get(found_url).content)
|
try:
|
||||||
|
found_url = "https://i.imgur.com/" + el['id'] + ".jpg" # equivalent to .png
|
||||||
if delete:
|
except KeyError:
|
||||||
Thread(target=delete_file, args=[f"{write_dir}{found_url[-11:]}"]).start()
|
error("Could not obtain url for detected image (id)")
|
||||||
|
continue
|
||||||
|
found_urls.append(found_url[-11:])
|
||||||
|
write(count, found_url, write_dir, delete)
|
||||||
# Write the found urls to a file with the name of the album so the viewer endpoint can get them
|
# Write the found urls to a file with the name of the album so the viewer endpoint can get them
|
||||||
found_list_file = write_dir + orig_url.replace('/', '_')
|
found_list_file = write_dir + orig_url.replace('/', '_')
|
||||||
with open(found_list_file, 'w') as f:
|
with open(found_list_file, 'w') as f:
|
||||||
f.write(','.join(found_urls))
|
f.write(','.join(found_urls))
|
||||||
Thread(target=delete_file, args=[found_list_file]).start()
|
Thread(target=delete_file, args=[found_list_file]).start()
|
||||||
|
|
||||||
|
def write(count: int, found_url: str, write_dir: str, delete=True):
|
||||||
|
print(f"Downloading image {count}: {found_url}")
|
||||||
|
|
||||||
|
print("Writing image", f"{write_dir}{found_url[-11:]}")
|
||||||
|
with open(f"{write_dir}{found_url[-11:]}", "wb") as f:
|
||||||
|
f.write(requests.get(found_url).content)
|
||||||
|
|
||||||
|
if delete:
|
||||||
|
Thread(target=delete_file, args=[f"{write_dir}{found_url[-11:]}"]).start()
|
||||||
|
Loading…
Reference in New Issue
Block a user