파이썬에서 두 개의 목록을 사전으로 결합하려면 어떻게 해야 합니까?
같은 길이의 목록이 두 개 있습니다.
[1,2,3,4]그리고.[a,b,c,d]
내가 가지고 있는 사전을 만들고 싶습니다.{1:a, 2:b, 3:c, 4:d}
이것을 하는 가장 좋은 방법은 무엇입니까?
dict(zip([1,2,3,4], [a,b,c,d]))
목록이 크면 사용해야 합니다.
값보다 키가 많은 경우 추가 키에 대한 값을 입력하려면 를 사용할 수 있습니다.
여기서,a,b,c,그리고.d변수입니다. (정의된 한) 잘 작동하겠지만, 아마도 당신은 의미했을 것입니다.['a','b','c','d']당신이 그것들을 끈으로 원한다면요.
zip 각 반복 가능한 항목에서 첫 번째 항목을 가져와 튜플을 만들고, 다음으로 각 항목에서 두 번째 항목을 만듭니다.
dict 반복 가능한 항목을 사용할 수 있습니다. 여기서 각 내부 항목에는 두 개의 항목이 있습니다. 첫 번째 항목을 키로 사용하고 두 번째 항목을 각 항목의 값으로 사용합니다.
>>> dict(zip([1, 2, 3, 4], ['a', 'b', 'c', 'd']))
{1: 'a', 2: 'b', 3: 'c', 4: 'd'}
만약 그것들이 같은 크기가 아니라면,zip더 긴 것을 잘라냅니다.
dict(zip([1,2,3,4], ['a', 'b', 'c', 'd']))
http://docs.python.org/library/functions.html
첫 번째 목록에 1대 다 관계와 같이 두 번째 목록의 다른 값에 매핑되는 중복 키가 있지만 업데이트하는 대신 값을 결합하거나 추가해야 하는 경우 다음 작업을 수행할 수 있습니다.
i = iter(["a", "a", "b", "c", "b"])
j = iter([1,2,3,4,5])
k = list(zip(i, j))
for (x,y) in k:
if x in d:
d[x] = d[x] + y #or whatever your function needs to be to combine them
else:
d[x] = y
그 예에서,d == {'a': 3, 'c': 4, 'b': 8}
가장 좋은 것(가장 간단한 것)에 대해서는 잘 모르겠습니다.가장 빠른가요? 가장 읽기 쉬운가요?) 하지만 한 가지 방법은:
dict(zip([1, 2, 3, 4], [a, b, c, d]))
저는 세 개의 목록(위도, 경도, 값)으로 구성된 사전을 만들어야 한다는 것을 알게 되었습니다. 다음과 같은 작업을 수행합니다.
> lat = [45.3,56.2,23.4,60.4]
> lon = [134.6,128.7,111.9,75.8]
> val = [3,6,2,5]
> dict(zip(zip(lat,lon),val))
{(56.2, 128.7): 6, (60.4, 75.8): 5, (23.4, 111.9): 2, (45.3, 134.6): 3}
또는 위의 예와 유사합니다.
> list1 = [1,2,3,4]
> list2 = [1,2,3,4]
> list3 = ['a','b','c','d']
> dict(zip(zip(list1,list2),list3))
{(3, 3): 'c', (4, 4): 'd', (1, 1): 'a', (2, 2): 'b'}
참고: 사전은 "순서가 없는" 사전이지만 "정렬된" 사전으로 보려면 키별로 정렬하려면 이 질문을 참조하고 값별로 정렬하려면 이 질문을 참조하십시오.
언급URL : https://stackoverflow.com/questions/7271385/how-do-i-combine-two-lists-into-a-dictionary-in-python
'programing' 카테고리의 다른 글
| 오류 코드: 1215.외부 키 제약 조건(외부 키)을 추가할 수 없습니다. (0) | 2023.07.30 |
|---|---|
| 변수가 있지만 "INTO"가 없는 단순 "SELECT" (0) | 2023.07.30 |
| Python에서 문자열의 이스케이프 시퀀스 처리 (0) | 2023.07.30 |
| PyDev "Import에서 정의되지 않은 변수" 오류를 해결하려면 어떻게 해야 합니까? (0) | 2023.07.30 |
| mysql 날짜에서 연도 변경 (0) | 2023.07.30 |