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

(시리즈 글이 8개 있습니다.)
.NET Framework: 614. C# - DateTime.Ticks의 정밀도
; https://www.sysnet.pe.kr/2/0/11082

.NET Framework: 827. C# - 인터넷 시간 서버로부터 받은 시간을 윈도우에 적용하는 방법
; https://www.sysnet.pe.kr/2/0/11883

스크립트: 33. JavaScript와 C#의 시간 변환
; https://www.sysnet.pe.kr/2/0/12849

Windows: 204.  Windows 10부터 바뀐 QueryPerformanceFrequency, QueryPerformanceCounter
; https://www.sysnet.pe.kr/2/0/13035

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

스크립트: 47. 파이썬의 time.time() 실숫값을 GoLang / C#에서 사용하는 방법
; https://www.sysnet.pe.kr/2/0/13308

닷넷: 2143. C# - 시스템 Time Zone 변경 시 이벤트 알림을 받는 방법
; https://www.sysnet.pe.kr/2/0/13413

닷넷: 2309. C# - .NET Core에서 바뀐 DateTime.Ticks의 정밀도
; https://www.sysnet.pe.kr/2/0/13803




파이썬의 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

비밀번호

댓글 작성자
 



2025-02-20 04시38분
Ubuntu - timezone 변경하는 방법

---------------------- 현재 timezone 확인

$ cat /etc/localtime
TZif2UTCTZif2UTC
UTC0

// 출력이 ascii로 보이지만, 실제로는 118 바이트의 데이터 파일
$ ls -l /usr/share/zoneinfo/Etc/UTC
-rw-r--r-- 1 root root 118 Feb 1 21:04 /usr/share/zoneinfo/Etc/UTC

---------------------- Asia/Seoul로 변경

$ sudo timedatectl set-timezone Asia/Seoul

$ cat /etc/localtime
...[binary 출력]...
KST-9

---------------------- GMT로 변경

// GMT는 "Etc/GMT"의 링크
// "Etc/Greenwich"도 "Etc/GMT"의 링크
$ sudo timedatectl set-timezone GMT

$ cat /etc/localtime
TZif2GMTTZif2GMT
GMT0


---------------------- "Europe/London"으로 변경

$ sudo timedatectl set-timezone Europe/London

$ cat /etc/localtime
...[binary 출력]...
GMT0BST,M3.5.0/1,M10.5.0

---------------------- 다시 UTC로 변경

// UTC는 "Etc/UTC"의 링크
// "Etc/UCT"도 "Etc/UTC"의 링크
// "Etc/Universal"도 "Etc/UTC"의 링크
$ sudo timedatectl set-timezone UTC

$ cat /etc/localtime
TZif2UTCTZif2UTC
UTC0
정성태

... 166  167  168  169  170  171  172  [173]  174  175  176  177  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
679정성태3/15/200920097오류 유형: 72. IE 8 멈춤 현상 - 두 번째 이야기
678정성태3/15/200925308개발 환경 구성: 37. Hyper-V에서 Vista의 Virtual Machine Bus 장치 인식 문제
677정성태3/15/200925794개발 환경 구성: 36. MSI P45 Neo3-FR V2 - RAID 1 구성
997정성태2/26/201121052    답변글 개발 환경 구성: 36.1. 개발 환경 구성: 34 - 1. RAID 1 구성 이후...
676정성태3/15/200922423오류 유형: 71. IE 8 RC1 - 멈춤 현상
675정성태3/14/200925313오류 유형: 70. Virtual Machine Additions 제거
673정성태3/11/200923907웹: 10. 금일 진행되었던 마이크로소프트 IE 8 행사의 ActiveX 세션 PPT [6]파일 다운로드1
672정성태3/1/200936908Windows: 43. Loopback network adapter 설치하기 [2]
670정성태2/22/200930059.NET Framework: 124. IIS 7에서 SVC 호스팅 [1]
669정성태2/21/200924471오류 유형: 69. The SQL Server Network Interface library could not register the Service Principal Name (SPN) for the SQL Server service.
668정성태2/21/200929538개발 환경 구성: 35. SQL Express 버전과 User Instance 옵션
667정성태2/14/200941475웹: 9. IE 7. IWebBrowser2 인터페이스 메서드의 Navigate / Navigate2 차이점 [3]파일 다운로드1
666정성태2/12/200927282웹: 8. IE 8: 프로세스와 윈도우의 관계 - LCIE [1]파일 다운로드1
665정성태2/7/200924207웹: 7. Internet Explorer 8 - XHR, XDR, XST, XSRF [1]
664정성태2/5/200920282Windows: 42. Concurrency Runtime
663정성태2/5/200924971.NET Framework: 123. WPF - Arial Narrow 폰트 문제
662정성태2/3/200920657VS.NET IDE: 59. HyperAddin 도구 사용 설명 [1]
661정성태2/3/200924355오류 유형: 68. msxml6r.dll 설치 오류
660정성태2/3/200922976Windows: 41. UAC 보안 취약 [2]
659정성태2/2/200934307오류 유형: 67. ClickOnce 응용 프로그램이 실행되지 않을 때.
658정성태2/1/200926323Team Foundation Server: 30. 소스 서버 보안
657정성태2/1/200929247Windows: 40. Q1 Ultra + Windows 7 베타
656정성태2/1/200930752디버깅 기술: 24. .NET JIT 최적화 코드 생성 제어
655정성태1/31/200926991Windows: 39. IE8 표준 모드 [4]
653정성태1/29/200921893.NET Framework: 122. XML Serializer를 이용한 값 복사: 성능은 어떨까!파일 다운로드1
652정성태1/22/200922728.NET Framework: 121. WPF - PrintTicket provider failed to bind to printer.
... 166  167  168  169  170  171  172  [173]  174  175  176  177  178  179  180  ...