python for문 질문드립니다.
글쓴이: magomzz / 작성시간: 수, 2018/05/09 - 4:52오후
어떤 포럼사이트에서 인용글 카테고리를 만드는 로직을 짜고 있는데요..
쉽게말해 A라는 글을 B와 C가 인용하면 A꾸러미하나 B라는 글을 D와E가 인용하면 B꾸러미하나 이런 로직인데..
예를 들어
art1 = ["A",'B','C','D','E','F'] quote = ["",'A','A','C','C','A'] g2 = pd.DataFrame({"Article":art1,"Quote":quote})
이런 g2라는 데이터 프레임에서 A의 글을 인용한 B,C,F를 묶고, C의 글을 인용한 D,F를 묶고 이런식인데
이것까지는 코드를 짰습니다.
dic = [] dic2 = [] for i in range(0,len(art1)) : dic.append(art1[i]) dic2.append("") for j in range(1,len(quote)): if art1[i] == quote[j]: dic2.append(art1[j]) dic.append("") g3 = pd.DataFrame(OrderedDict({"Article":dic,"Quote":dic2}))
그런데 C가 A 카테고리에 들어가 있어서 C를 인용한 D,F도 A카테고리에 함께 넣을려고 하는데..
로직을 어떻게 짜야할지 모르겠어서 질문드립니다...!
감사합니다!
Forums:
list comprehension 사용
List comprehension을 사용하면 좀 더 python처럼 만들 수 있습니다.
두 번째 문제는 dict 사전의 key를 가지고 value를 검사하여 value에 key가 있으면 그 key에 해당하는 value를 뒤에 붙이면 될 것 같습니다. 그런데, 인용한 것이 없으면 value가 빈 list이므로, list 길이를 확인하여 처리해야 합니다.
감사합니다
그런데 A를 직접적으로 인용한F와 이중인용으로 들어온 D와E를 구분할 수 있는 방법이 있을까요?
이중 사전 사용
원문과 인용이 1:1로 서로 연관 관계가 있어서 사전을 사용했는데, 깊이가 하나 더 늘어나면 사전의 값으로 사용했던 list를 다시 dictionary로 바꿔야 할 것 같습니다. 두 단계까지는 어찌 어찌 되는데, 인용 깊이가 더 깊어지면 근본적으로 구조 또는 접근 방법을 다시 생각해 봐야 할 것 같습니다.
먼저, art1, quote에서 원문을 key로 하고 인용한 문들을 list value로 했었는데, 이 value를 list가 아닌 사전(dictionary)으로 만듭니다.
이렇게 하면 목록이 key이고 value에 인용 목록 list가 있던 것이 목록이 key이고 value에 다시 사전이 만들어지는데, 이 하부 사전의 key는 인용 목록이고 value는 빈 list 입니다. 이제 이 빈 list에 재 인용한 목록이 있으면, 이것을 찾아 넣어 줍니다.
댓글 달기