괄호를 처리할 수 있는 사칙연산 계산기 (Python)

파이썬으로 간단한 사칙연산 계산기를 만들어보자. 실질적으로는 간단한 계산을 명령줄에서 수행할 수 있는 계산기가 필요해서 (계산기 앱을 실행하는게 귀찮…) 만들어보기로 했다.

실질적으로 간단한 덧셈, 나눗셈이 아니라, 다항식을 계산하고, 괄호가 들어있는 수식을 계산하는 기능이 필요했다. 따라서입력 자체는 명령줄 인자로 받으며, 가능한 한 ‘관대하게’ 처리하고자 했다.

이를 위해서는 입력받은 식을 공백이나 연산기호를 구분점으로 파싱하고, 후위식으로 변환한 후 이 후위식을 하나의 항으로 계산한 다음, 그 결과를 출력해주면 된다. 이들 각각의 과정을 함수로 만들고 최종적으로 하나의 코드로 조립해나간다.

괄호를 처리할 수 있는 사칙연산 계산기 (Python) 더보기

20110621 :: NSString 사용하기

NSString에서 알아두어야할 몇가지 메소드들을 정리해본다.

문자열 생성

포맷에 맞게 문자열을 생성하기

+stringWithFormat: 메소드를 사용한다.

NSString *newStr = [NSString stringWithFormat:@"%@ : %d", someObj.name, someObj.score];

-initWithFormat:의 경우 같은 동작을 하지만, 이 때는 수동으로 alloc하므로 릴리즈의 책임을 져야 한다.

C문자열로부터 생성

initWithUTF8String:, stringWithUTF8String: 을 통해서 const char* 데이터를 NSString 객체로 바꿀 수 있다. 1

다른 인코딩을 된 문자열이라면 initWithCString:encoding:, stringWithCString:encoding:을 사용할 수 있다.

바이너리 데이터로부터 생성

NSData(파일을 읽어들였거나, 네트워크 스트림으로부터 받은)객체로도 이를 만들 수 있다. initWithData:encoding:을 쓴다. 특히 파일의 경우, stringWithContentsOfFile:encoding:error:stringWithContentsOfURL:encoding:error:를 쓸 수 있다.

파일에 쓰기

-writeToFile:atomically:encoding:error:이 가장 기본적인 파일 쓰기 함수이다. URL 베이스의 -writeToURL:atomically:encoding:error:도 있다. 미리 파일을 열고 닫을 필요가 없다.

속성

길이구하기

-length 프로퍼티를 이용한다. 이는 유니코드 문자의 개수를 돌려주는데, 만약 특정 인코딩으로 변환한 후의 데이터 크기를 알고 싶다면 -lengthOfBytesUsingEncoding:을 쓴다.

서브스크립트

특정 위치의 글자는 characterAtIndex:로 구한다. (반환형은 unichar로 유니코드 문자 한 개의 값이다.) 서브 스트링을 구할 때는 getCharacters:range:를 쓴다. 이는 NSString을 돌려주는게 아니라 unichar* 타입의 포인터를 받아서 range만큼 뽑아 복사해준다.

NSString 객체로 된 서브스트링을 얻으려면 substringWithRange:substringFromIndex:, substringToIndex:를 쓴다.

C 문자열 얻기

UTF8String 속성을 사용한다. 별도 인코딩을 쓰려면 cStringUsingEncoding:을 쓴다.

문자열 결합하기

문자열의 배열을 하나로 join 하는 것은 NSArray의 componensJoinedByString:을 사용하면 된다. 그외 다른 문자열을 결합하기위해서는 stringByAppendingString: 이나 stringByAppendingFormat:을 쓴다. (한번 생성된 문자열은 내부 데이터를 변경할 수 없으므로 새로운 문자열을 만들어야 한다.)

문자열 나누기

문자열을 특정 토큰으로 나누어 배열로 만드려면 componentsSeparatedByString: 이나 componentsSeparatedByCharactersInSet:을 이용한다.

문자열 내에서 특정 문자/문자열 찾기

가장 많이 쓰이는 것은 rangeOfString:이다.

문자열 바꾸기

서브스트링 치환은 stringByReplacingOccurrencesOfString:withString:이다. 추가로 범위나 옵션 제한을 두는 stringByReplacingOccurrencesOfString:options:range:도 있다. 그냥 특정 범위를 다른 문자열로 바꾸는 stringByReplacingCharactersInRange:withStirng:도 있다.

프로퍼티리스트 변환

프로퍼티 리스트 파싱을 자동으로 할 수 있다. propertyList, propertyListFromStringsFileFormat 문자열을 프로퍼티리스트로 파싱하면 사전 객체를 리턴해준다.

비교

정렬을 위해서 비교 구문을 쓴다. compare:는 합성글리프에 대한 연산이 정확하지 않으므로 localizedCompare:localizedCaseInsentiveCompare:를 많이 쓴다. 비교 함수의 결과는 NSComparisonResult로 이는 NSOrderAscending | NSOrderEqual | NSOrderDescending중 하나가 된다.

케이스 변환

capitalizedString, lowercaseString, uppercaseString 등이 있다.

숫자값

문자열 내용이 숫자인 경우 intValue, floatValue… 등의 즉시 변환 함수가 있다.

그외 다음 기능들이 있는데, 다 못적겠다….
* URL:
* 퍼센트로 인코딩하기
* file path:
* 파일 경로 구분자 추가/확장하기
* 확장자 확장


  1. initWithCString:, stringWithCString: 이라는 메소드가 있었지만, 없어졌다. 대신 인코딩방식을 주는 것은 가능하다. 

20110621 :: Objective-C의 문자열 포맷팅

Formatting Specifier

전체 내용을 정리한 것은 아니지만 참고 삼아.

  • %@ : 종류에 무관하게 Objective-C 객체를 의미한다. 대부분 descriptionWithLocale이나 description 이 출력된다. NSString을 포맷팅할 때 사용한다.
  • %% : “%” 문자
  • %d, %D, %i : singed-32bit 정수
  • %u, %U : Unsigend-32bit 정수
  • %hi : signed-16bit 정수
  • %ui : unsigned-16bit 정수
  • %qi : signed-64bit 정수
  • %qu : unsigned-64bit 정수
  • %x : signed-32bit 정수를 16진수로 표기함
  • %X : unsigned-32bit 정수를 16진수로 표기함
  • %qx : signed-64bit 정수를 16진수로 표기함
  • %qX : unsigned-64bit 정수를 16진수로 표기함
  • %o, %O : unsigned-32bit 정수를 8진수로 표기함
  • %f : 64비트 소수 (double)
  • %e : 64비트 소수를 부동소수점 형태로 표기함 ex. 3.242343e25
  • %E : 64q비트 소수를 부동소수점 형태로 표기하는데, 대문자 E를 사용함 ex. 8.34234354E5
  • %c : 8비트 unsigned char 문자. 아스키코드일 때는 아스키문자가 표시되고 그외에는 숫자값으로 표시된다.
  • %C : 16비트 유니코드 문자. 아스키코드일때는 아스키문자로 표시되고 그 외에는 u가 앞에 붙는 숫자값으로 표시된다.
  • %s : 널문자로 종료되는 8비트 문자열
  • %S : 널문자로 종료되는 16비트 유니코드 문자열
  • %p : 0x9a와 같이 16진수로 표기되는 void 포인터