Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

파이썬의 time.time() 실숫값을 GoLang / C#에서 사용하는 방법

파이썬의 time.time()은,

import time

print(time.time())  # 1680616014.57

문서에 epoch time의 부동소수점 형식이라고 합니다. 일단 정수 영역은 초 단위이고, 소수점 이하는 초 단위 이하의 정밀도를 나타냅니다. 가령, 위의 경우 0.5는 5/10초이고, 0.07은 7/100초입니다.

제 Windows에서 여러 차례 시도해 보면, 소수점 7자리까지 나오는데요 따라서 1/10 마이크로초 단위, 즉 100 나노 초까지 나옵니다. 그런데 어딘가 좀 익숙한 단위죠. ^^

C# - nano 시간을 가져오는 방법
; https://www.sysnet.pe.kr/2/0/13036

(time.time이 반환하는 정밀도는 시스템마다 다를 수 있다는 것을 염두에 둬야 합니다.)

자, 그렇다면 이제 저 값을 밀리 초, 마이크로 초까지 변환하는 것을 쉽게 할 수 있습니다.

milli_time = int(time.time() * 1000)
micro_time = int(time.time() * 1000000)

비록 time.time() 값이 100 나노 초 단위까지 값을 생성하긴 하지만 이 값을 datetime 등으로 변환하면 마이크로 초 단위에서 잘립니다.

from datetime import datetime
print(datetime.fromtimestamp(1680616014.7561996))  # 2023-04-04 22:46:54.756200

print(datetime.fromtimestamp(1680616014.75))     # 1680616014.750000
print(datetime.fromtimestamp(1680616014.750000)) # 1680616014.750000
print(datetime.fromtimestamp(1680616014.000075)) # 1680616014.000075




파이썬의 time 값 구조를 알았다면 이제 이것을 Go 언어에서 읽는 것은 어렵지 않습니다. Go에서는 Epoch 시간을 Milli와 Micro 초 단위로 읽는 함수가 있기 때문에,

package main

import (
    "fmt"
    "time"
)

func main() {
    value := 1680616014.7561996
    value *= 1000000 // 마이크로 초로 변환

    timeValue := int64(value)

    fmt.Printf("%v\n", time.UnixMicro(timeValue)) // 2023-04-04 22:46:54.756199 +0900 KST
}

위와 같이 처리하면 됩니다. 한 가지 가벼운 문제가 있다면, 파이썬의 datetime.fromtimestamp은 100 나노 초에 대해 반올림을 하지만 위의 Go - int64 처리는 버림을 하기 때문에 굳이 이것을 맞춰야 한다면 다음과 같이 추가 처리를 해주시면 됩니다.

timeValue := math.Round(value)

fmt.Printf("%v\n", time.UnixMicro(int64(timeValue)))




간단하게 C#으로도 알아볼까요? ^^ 우선 밀리 초 단위까지만 보존해도 된다면 간단하게 DateTimeOffset을 쓰면 됩니다.

double value = 1680616014.7561996;
value *= 1000; // 밀리 초로 변환

Console.WriteLine(DateTimeOffset.FromUnixTimeMilliseconds((long)value).UtcDateTime);
// 출력: 2023-04-04 오후 1:46:54

반면 100나노 초까지 그대로 반영하고 싶다면 time.time()의 결과를 100 나노 단위로 올리고 Epoch Ticks 만큼의 크기를 더해주면 됩니다.

long UnixEpochTicks = 621355968000000000;

double value = 1680616014.7561996;
value *= 10000000; // 100 나노 초로 변환

DateTime date = new DateTime((long)value + UnixEpochTicks, DateTimeKind.Utc);
Console.WriteLine(date); // 2023-04-04 오후 1:46:54




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 4/6/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 46  47  48  49  50  51  52  53  54  55  56  57  58  59  [60]  ...
NoWriterDateCnt.TitleFile(s)
12139정성태2/9/202011443.NET Framework: 886. C# - Console 응용 프로그램에서 UI 스레드 구현 방법
12138정성태2/9/202014203.NET Framework: 885. C# - 닷넷 응용 프로그램에서 SQLite 사용 [6]파일 다운로드1
12137정성태2/9/20209361오류 유형: 592. [AhnLab] 경고 - 디버거 실행을 탐지했습니다.
12136정성태2/6/20209799Windows: 168. Windows + S(또는 Q)로 뜨는 작업 표시줄의 검색 바가 동작하지 않는 경우
12135정성태2/6/202013416개발 환경 구성: 468. Nuget 패키지의 로컬 보관 폴더를 옮기는 방법 [2]
12134정성태2/5/202013535.NET Framework: 884. eBEST XingAPI의 C# 래퍼 버전 - XingAPINet Nuget 패키지 [5]파일 다운로드1
12133정성태2/5/202010781디버깅 기술: 161. Windbg 환경에서 확인해 본 .NET 메서드 JIT 컴파일 전과 후 - 두 번째 이야기
12132정성태1/28/202012363.NET Framework: 883. C#으로 구현하는 Win32 API 후킹(예: Sleep 호출 가로채기)파일 다운로드1
12131정성태1/27/202012422개발 환경 구성: 467. LocaleEmulator를 이용해 유니코드를 지원하지 않는(한글이 깨지는) 프로그램을 실행하는 방법 [1]
12130정성태1/26/20209912VS.NET IDE: 142. Visual Studio에서 windbg의 "Open Executable..."처럼 EXE를 직접 열어 디버깅을 시작하는 방법
12129정성태1/26/202015423.NET Framework: 882. C# - 키움 Open API+ 사용 시 Registry 등록 없이 KHOpenAPI.ocx 사용하는 방법 [3]
12128정성태1/26/202010235오류 유형: 591. The code execution cannot proceed because mfc100.dll was not found. Reinstalling the program may fix this problem.
12127정성태1/25/202010104.NET Framework: 881. C# DLL에서 제공하는 Win32 export 함수의 내부 동작 방식(VT Fix up Table)파일 다운로드1
12126정성태1/25/202010951.NET Framework: 880. C# - PE 파일로부터 IMAGE_COR20_HEADER 및 VTableFixups 테이블 분석파일 다운로드1
12125정성태1/24/20208790VS.NET IDE: 141. IDE0019 - Use pattern matching
12124정성태1/23/202010619VS.NET IDE: 140. IDE1006 - Naming rule violation: These words must begin with upper case characters: ...
12123정성태1/23/202012115웹: 39. Google Analytics - gtag 함수를 이용해 페이지 URL 수정 및 별도의 이벤트 생성 방법 [2]
12122정성태1/20/20209071.NET Framework: 879. C/C++의 UNREFERENCED_PARAMETER 매크로를 C#에서 우회하는 방법(IDE0060 - Remove unused parameter '...')파일 다운로드1
12121정성태1/20/20209652VS.NET IDE: 139. Visual Studio - Error List: "Could not find schema information for the ..."파일 다운로드1
12120정성태1/19/202011093.NET Framework: 878. C# DLL에서 Win32 C/C++처럼 dllexport 함수를 제공하는 방법 - 네 번째 이야기(IL 코드로 직접 구현)파일 다운로드1
12119정성태1/17/202011119디버깅 기술: 160. Windbg 확장 DLL 만들기 (3) - C#으로 만드는 방법
12118정성태1/17/202011792개발 환경 구성: 466. C# DLL에서 Win32 C/C++처럼 dllexport 함수를 제공하는 방법 - 세 번째 이야기 [1]
12117정성태1/15/202010783디버깅 기술: 159. C# - 디버깅 중인 프로세스를 강제로 다른 디버거에서 연결하는 방법파일 다운로드1
12116정성태1/15/202011256디버깅 기술: 158. Visual Studio로 디버깅 시 sos.dll 확장 명령어를 (비롯한 windbg의 다양한 기능을) 수행하는 방법
12115정성태1/14/202011031디버깅 기술: 157. C# - PEB.ProcessHeap을 이용해 디버깅 중인지 확인하는 방법파일 다운로드1
12114정성태1/13/202012876디버깅 기술: 156. C# - PDB 파일로부터 심벌(Symbol) 및 타입(Type) 정보 열거 [1]파일 다운로드3
... 46  47  48  49  50  51  52  53  54  55  56  57  58  59  [60]  ...