본문 바로가기

Python/Python FAQ540

Python 판다스 데이터프레임에서 두 개의 열 텍스트를 결합하세요., Combine two columns of text in pandas dataframe 질문 파이썬에서 판다스를 사용하여 20 x 4000 데이터프레임을 가지고 있습니다. 이 중 두 개의 열은 Year와 quarter로 지정되어 있습니다. Year = 2000 및 quarter= q2를 2000q2로 만드는 period이라는 변수를 만들고 싶습니다. 도와주실 분 계신가요? 답변 두 열이 모두 문자열인 경우 직접 연결할 수 있습니다: df["period"] = df["Year"] + df["quarter"] 하나 이상의 열이 문자열이 아닌 경우 먼저 변환해야합니다. df["period"] = df["Year"].astype(str) + df["quarter"] 이 때 NaN에 주의하십시오! 여러 문자열 열을 결합해야하는 경우 agg를 사용할 수 있습니다: df['period'] = df[['.. 2023. 6. 9.
Python 사전에서 값으로 키 가져오기, Get key by value in dictionary 질문 나는 Dictionary에서 나이를 찾아 일치하는 이름을 보여줄 함수를 만들었다: dictionary = {'george' : 16, 'amber' : 19} search_age = raw_input("나이를 입력하세요") for age in dictionary.values(): if age == search_age: name = dictionary[age] print name 나는 비교하고 나이를 찾는 방법을 알고 있지만, 그 사람의 이름을 표시하는 방법을 모르겠다. 또한, 5번째 줄 때문에 KeyError가 발생한다. 이것이 올바르지 않다는 것을 알고 있지만, 역으로 검색하는 방법을 찾을 수 없다. 답변 mydict = {'george': 16, 'amber': 19} print mydict.k.. 2023. 6. 9.
Python 파이썬 애플리케이션을 위한 최상의 프로젝트 구조는 무엇인가요? [닫힘], What is the best project structure for a Python application? [closed] 질문 파이썬으로 비단순한 엔드 유저 데스크탑 (웹이 아님) 애플리케이션을 개발하려는 경우, 프로젝트의 폴더 계층 구조를 구성하는 최상의 방법은 무엇인가요? 유지 보수의 용이성, IDE 친화성, 소스 컨트롤 브랜치/병합에 적합성 및 쉬운 설치 패키지 생성이 필요한 기능입니다. 특히 다음과 같습니다: 소스를 어디에 넣나요? 애플리케이션 시작 스크립트를 어디에 넣나요? IDE 프로젝트 부산물을 어디에 넣나요? 단위/인수 테스트를 어디에 넣나요? 구성 파일과 같은 비-Python 데이터를 어디에 넣나요? pyd/so 바이너리 확장 모듈을 위한 비-Python 소스를 어디에 넣나요? 답변 너무 중요하지 않습니다. 행복하게 하는 것이 작동합니다. Python 프로젝트는 간단할 수 있으므로 많은 어리석은 규칙이 없습.. 2023. 6. 9.
Python 다중 생성자를 구현하는 깨끗하고 "파이썬스러운" 방법은 무엇인가요?, What is a clean "pythonic" way to implement multiple constructors? 질문 이에 대한 명확한 답변을 찾을 수 없습니다. 제가 알기로는 Python 클래스에서 __init__ 함수를 여러 개 가질 수 없습니다. 그렇다면 이 문제를 어떻게 해결할까요? number_of_holes 속성을 가진 Cheese 클래스가 있다고 가정해 봅시다. 이러한 방식으로 치즈 객체를 생성하는 두 가지 방법이 필요합니다... num_holes = 15와 같은 구멍 수를 입력 받는 방법: parmesan = Cheese(num_holes = 15). 인수를 입력받지 않고 number_of_holes 속성을 무작위로 생성하는 방법: gouda = Cheese(). 이를 수행하는 유일한 방법은 다음과 같지만, 이 방법은 복잡해 보입니다: class Cheese(): def __init__(self, n.. 2023. 6. 7.