• 목록
  • 아래로
  • 위로

안녕하세요??

 

주말 잘 보내고 계시는가요?? ^-^

 

from concurrent.futures import ThreadPoolExecutor을 이용하여 다수의 이미지를 크롤링하는 경우에 대해 질문 드립니다.

 

def down_file(url, s, name, dir):
    r = s.get(url)
    if r.status_code == 200:
        filename = dir + '\\' + name
        print(filename)
        with open(filename, 'wb') as f:
            f.write(r.content)
    return s

with ThreadPoolExecutor(max_workers=8) as executor:
    for p in prvs:
        href = p.find('a')['href']
        url =  'URL을 입력하세요' + href
        html = s.get(url).content
        soup = BeautifulSoup(html, 'html5lib')
        a_tags = soup.find('div', {'id':'galerie-listing-photos'}).find_all('a')
        for a in a_tags:
            url = 'URL을 입력하세요' + a['href']
            name = url.split('/')[-1]
            executor.submit(down_file, url, s, name, dir)

 

이와 같이 with 문을 사용하여 실행을 해봤고, 아래와 같이 with 문을 사용하지 않고 실행을 해봤어요~!

 

 

# 다운로드 함수 생략

pool = ThreadPoolExecutor(max_workers=8)
for p in prvs:
    href = p.find('a')['href']
    url =  'URL을 입력하세요' + href
    html = s.get(url).content
    soup = BeautifulSoup(html, 'html5lib')
    a_tags = soup.find('div', {'id':'galerie-listing-photos'}).find_all('a')
    for a in a_tags:
        url = 'URL을 입력하세요' + a['href']
        name = url.split('/')[-1]
        pool.submit(down_file, url, s, name, dir)

 

 

그런데 전자가 후자보다 다운로드 받은 파일 수가 더 많은데요 ㅠㅠ

 

후자에서 어떤 문제가 발생한 것 같은데 무엇 때문에 이러한 문제가 발생했는지 여쭤봅니다.

 

with 문으로 사용하지 않으면 스레드 간에 충돌이 발생하는건가요??

 

 

그럼 비 조심하시고 편안한 주말 되세요 :)

 

항상 감사드려요!! ^^

 

작성자
이니스프리 119 Lv. (1%) 2382020/115200000EXP

Make StudyForUs Great Again!

 

CSVpuymXAAAVVpd.jpg

댓글 4

title: 황금 서버 (30일)humit
profile image
+1
https://docs.python.org/3/library/concurrent.futures.html#concurrent.futures.Executor.shutdown
이 내용이 도움이 되실 거 같네요.
comment menu
2020.08.09. 23:36

신고

"humit님의 댓글"

이 댓글을 신고 하시겠습니까?

이니스프리 작성자 → humit
profile image
humit 님 안녕하세요??
번번이 큰 도움을 주셔서 정말 감사합니다!!

공식문서를 읽는 습관을 들여야 된다는 생각은 늘 하는데...
이번에도 제가 깜빡했네요 ㅠㅠㅠㅠㅠ

제가 제대로 이해했는지 모르겠지만 Executor 인스턴스를 shutdown 하지 않으면
어디에선가 꼬이는가 보군요 ㅜㅜ
구글링해봐도 with 문을 사용하는 경우가 대부분이네요!

병렬작업 실행은 잘 작성하면 정말 효율적인데 저한테는 아직 어렵네요 ㅠㅠ
제가 구매한 서적들에는 이 부분을 제대로 다루지 않던데 어떻게든 더 공부를 해봐야겠어요~
그럼 humit 님께서도 좋은 오후 되시고 태풍이 온다던데 피해가 없으시길 기원할게요!
항상 감사드려요!
comment menu
2020.08.10. 13:41

신고

"이니스프리님의 댓글"

이 댓글을 신고 하시겠습니까?

title: 황금 서버 (30일)humit → 이니스프리
profile image
+1
좀더 상세하게 말씀드리자면 shutdown 메서드를 사용하지 않으면 메인 프로세스가 종료된 경우 Executor에 들어온 작업이 실행이 끝날 때까지 대기하는 것이 아니라 바로 종료가 되게 됩니다. 그래서 두 번째 경우에 실행되다가 중간에 종료가 되어서 개수가 적은 것이라고 생각하시면 됩니다.
comment menu
2020.08.11. 23:08

신고

"humit님의 댓글"

이 댓글을 신고 하시겠습니까?

이니스프리 작성자 → humit
profile image
앗 그런 과정에서의 차이가 발생하여 결과가 달라지는 것이군요~ ^-^
정말 감사합니다!!
덕분에 또 많이 배웠네요 :)
그럼 humit 님께서도 비 조심하시고 굿밤 되세요!
comment menu
2020.08.11. 23:18

신고

"이니스프리님의 댓글"

이 댓글을 신고 하시겠습니까?

권한이 없습니다.
번호 제목 글쓴이 날짜 조회 수
공지 [작업 완료] 설 명절 맞이 서버 업데이트 안내 3 마스터 24.02.11.17:21 1184
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 4 마스터 23.01.14.02:23 4872
공지 [필독] 질문하는 방법 17 마스터 18.02.23.03:09 4485
46 호스팅 세팅 도움주실분 급하게 찾아요 ㅠ.ㅠ 1 HOya 17.01.23.07:30 355
45 IIS에서 한 사이트 내에서 폴더에 각각 도메인 지정 못하나요? 17 title: 황금 서버 (30일)하루살이 17.01.19.13:57 1298
44 집에서 시놀로지 NAS로 워드프레스나 미디어위키 돌리면 느릴까요? 10 이니스프리 17.01.16.20:56 2991
43 포인트 복권 게시글처럼 출력하는 방법 아시는 분 있나요?? 4 시루떡 17.01.16.01:16 270
42 구서버 패널 로그인이 안됩니다. 3 image ryuko 17.01.12.20:50 401
41 신서버 패널 점검중인가요? 1 title: 도밥위키!Dobob 17.01.10.23:08 251
40 OwnCloud가 망가지고,FTP도 안됩니다..ㅜㅜ 5 image title: 맛스타의 자물쇠에듀 17.01.10.14:46 537
39 메일 수신이 안됩니다... 4 title: 도밥위키!Dobob 17.01.08.11:39 287
38 친애하는 마스터님 어제 호스팅을 신청해서 정상적으로 받아졌습니다. 2 JongMinMoon 16.12.27.16:47 762
37 [신서버] 저만 이런 문제가 발생하나요? 5 image title: 은메달도다 16.12.27.15:23 441
36 신서버에 서비스를 신청헸는데, 새로운 도메인에 접속이 되지 않아요. 1 워시퍼 16.12.26.22:40 307
35 디비 관련 2 image title: 은메달대전댁 16.12.03.16:09 273
34 혹시 ajax chat 사용해보신분? 1 막시모 16.11.17.16:06 343
33 호스팅 Bandwidth와 속도에 대해서 궁금한 점이 있습니다. 1 RonnieJ 16.11.17.11:00 402
32 타 호스팅 업체에 있는 것들 옴기는 방법이 있나요? 4 BlackTeddyBear 16.11.12.17:23 438
31 실수로 게시판을 지워버려 자료가 다 날라갔습니다 ㅠㅠ 혹시 하루전 데이터로 복구가 가능할까요? ㅠㅠ 4 김인수 16.11.09.11:28 337
30 기본 제공 도메인에 체크를 안했습니다 ㅠㅠ 2 라하하 16.11.07.17:19 391
29 저의 주소는 어떻게 되는지요. 7 gobiyah 16.10.30.18:06 369
28 ftp마운트좀 해주세요 마스터님 11 djdisodo 16.10.28.22:15 449
27 호스팅을할떄에 5 Sein&Music 16.10.27.11:50 358