숫자 문자열이있는 목록이 있습니다.
numbers = ['1', '5', '10', '8'];
모든 목록 요소를 정수로 변환하고 싶으므로 다음과 같습니다.
numbers = [1, 5, 10, 8];
루프를 사용하여 다음과 같이 할 수 있습니다.
new_numbers = [];
for n in numbers:
new_numbers.append(int(n));
numbers = new_numbers;
너무 못 생겼나요? 한 줄의 코드로이를 수행하는 더 파이썬적인 방법이 있다고 확신합니다. 도와주세요.
답변
이것이 목록 이해 의 대상입니다.
numbers = [ int(x) for x in numbers ]
답변
Python 2.x에서 또 다른 접근법은 다음을 사용하는 것입니다 map
.
numbers = map(int, numbers)
참고 : Python 3.x map
에서는 원하는 경우 목록으로 변환 할 수있는 맵 객체를 반환합니다.
numbers = list(map(int, numbers))
답변
요점 만
numbers = [int(x) for x in numbers]
목록 이해력이 더 자연스럽고
numbers = map(int, numbers)
가 더 빠르다.
아마도 이것은 대부분의 경우 중요하지 않을 것입니다
유용한 읽기 : LP 대 맵
답변
해당 정수를 함수 또는 메소드에 전달하려는 경우 다음 예제를 고려하십시오.
sum(int(x) for x in numbers)
이 구성은 의도적으로 adamk가 언급 한 목록 이해와 매우 유사합니다. 대괄호가 없으면 생성기 표현식 이라고하며 인수 목록을 메소드에 전달하는 매우 메모리 효율적인 방법입니다. 여기서 좋은 토론을 볼 수 있습니다 : 제너레이터 표현식과리스트 이해
답변
파이썬 3에서 만드는 또 다른 방법 :
numbers = [*map(int, numbers)]
답변
또 다른 방법,
for i, v in enumerate(numbers): numbers[i] = int(v)
답변
답변을 정리하고 일부를 보여줄 것이라고 생각했습니다. timeit
결과를 .
파이썬 2는 이것에 꽤 나쁘지만 map
이해력보다 약간 빠릅니다.
Python 2.7.13 (v2.7.13:a06454b1afa1, Dec 17 2016, 20:42:59) [MSC v.1500 32 bit (Intel)] on win32
Type "copyright", "credits" or "license()" for more information.
>>> import timeit
>>> setup = """import random
random.seed(10)
l = [str(random.randint(0, 99)) for i in range(100)]"""
>>> timeit.timeit('[int(v) for v in l]', setup)
116.25092001434314
>>> timeit.timeit('map(int, l)', setup)
106.66044823117454
파이썬 3 자체는 4 배 이상 빠르지 만 map
생성기 객체를 목록으로 변환하는 것이 여전히 이해력보다 빠르며 map
생성기 를 풀고 (Artem! 덕분에) 목록을 생성하여 목록을 생성하는 것이 약간 더 빠릅니다.
Python 3.6.1 (v3.6.1:69c0db5, Mar 21 2017, 17:54:52) [MSC v.1900 32 bit (Intel)] on win32
Type "copyright", "credits" or "license()" for more information.
>>> import timeit
>>> setup = """import random
random.seed(10)
l = [str(random.randint(0, 99)) for i in range(100)]"""
>>> timeit.timeit('[int(v) for v in l]', setup)
25.133059591551955
>>> timeit.timeit('list(map(int, l))', setup)
19.705547827217515
>>> timeit.timeit('[*map(int, l)]', setup)
19.45838406513076
참고 : 파이썬 3에서 4 요소는 이해력이 약간 더 빠르지 만 교차 요소 (파이썬 2에서는 3) 인 것처럼 보입니다. 생성자를 풀면 여전히 요소가 2 개 이상인 목록의 경우보다 빠릅니다.