C#编程练习(03):北斗时间系统、GPS时间系统及其与UTC时间系统之间的转换

简介: C#编程练习(03):北斗时间系统、GPS时间系统及其与UTC时间系统之间的转换

需求说明:北斗周-周内秒转化为日历时,转化为UTC时,转化为GPS周周内秒

GPS周-周内秒转化为日历时,转化为UTC时,转化为北斗周-周内秒

设计示意图:

20181126094558863.jpg

源代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
//这是一个BDS/GPS周、周内秒与日历时、UTC时的转换与逆转换程序
//自定义缩略语说明:WIS为周内秒,week inner second; NYR,年月日的拼音首字母缩写
//本程序主要实现以下几个功能:
//(1) GPS Week WIS  <-->  NYR
//(2) GPS Week WIS  <-->  UTC
//(3) BDS Week WIS  <-->  NYR
//(4) BDS Week WIS  <-->  UTC
//(5) BDS Week WIS  <--> GPS Week WIS 
namespace BDS_GPS_UTC
{
    class Program
    {
        ///功能模块一:GPS周-周内秒与日历时的转换与逆转换///
        //GPS周-周内秒到年月日系统的转换
        static private DateTime gpsWeekWIS2NYR(int gpsWeek, int gpsWIS)
        {
            int difFromBegin = gpsWeek * 604800 + gpsWIS;
            DateTime gpsBeginTime = new DateTime(1980,1,6,0,0,0);
            return gpsBeginTime.AddSeconds(difFromBegin);
        }
        //GPS日历时与周-周内秒的转换
        static private int[] gpsNYR2WeekWIS(DateTime gpsNYR)
        {
            int[] gpsWeekWIS = {0, 0};               
            DateTime gpsBeginUTC = new DateTime(1980,1,6,0,0,0);
            //计算两个UTC时的时间间隔
            TimeSpan interval = gpsNYR - gpsBeginUTC;
            int gpsWeek = (int)interval.TotalSeconds / 604800;
            int gpsWIS = (int)interval.TotalSeconds % 604800;
            gpsWeekWIS[0] = gpsWeek;
            gpsWeekWIS[1] = gpsWIS;
            return gpsWeekWIS;
        }
        ///功能模块二:GPS周-周内秒与UTC时间系统的转换与逆转换///
        //GPS周-周内秒到UTC时间系统的转换
        static private DateTime gpsWeekWIS2UTC(int gpsWeek, int gpsWIS)
        {
            DateTime gpsNYR = gpsWeekWIS2NYR(gpsWeek, gpsWIS);
            //GPS日历时比UTC时快18秒
            return gpsNYR.AddSeconds(-18.0);
        }
        //GPS UTC时间系统到周-周内秒的转换
        static private int[] gpsUTC2WeekWIS(DateTime gpsUTC)
        {
            return gpsNYR2WeekWIS(gpsUTC.AddSeconds(18));
        }
        ///功能模块三:BDS周-周内秒与日历时的转换与逆转换///
        //BDS周-周内秒到年月日时间系统的转换
        static private DateTime bdsWeekWIS2NYR(int bdsWeek, int bdsWIS)
        {
            int difFromBegin = bdsWeek * 604800 + bdsWIS;
            DateTime bdsBeginTime = new DateTime(2006, 1, 1, 0, 0, 0);
            return bdsBeginTime.AddSeconds(difFromBegin);
        }
        //年月日时间系统到BDS周-周内秒的转换
        static private int[] bdsNYR2WeekWIS(DateTime bdsNYR)
        {
            //先转换到UTC时间系统
            DateTime bdsBeginUTC = new DateTime(2006, 1, 1, 0, 0, 0);
            //计算当前UTC回推出BDS起始时刻UTC的时间差
            TimeSpan interval = bdsNYR - bdsBeginUTC;
            int[] bdsWeekWIS = {0,0};
            int bdsWeek = (int)interval.TotalSeconds / 604800;
            int bdsWIS = (int)interval.TotalSeconds % 604800;
            bdsWeekWIS[0] = bdsWeek;
            bdsWeekWIS[1] = bdsWIS;
            return bdsWeekWIS;
        }
        ///功能模块四:BDS周-周内秒与UTC时间系统的转换与逆转换///
        //BDS周-周内秒到UTC时间系统的转换
        static private DateTime bdsWeekWIS2UTC(int bdsWeek, int bdsWIS)
        {
            DateTime bdsNYR = bdsWeekWIS2NYR(bdsWeek, bdsWIS);
            //BDS日历时比UTC时快4秒
            return bdsNYR.AddSeconds(-4.0);
        }
        //UTC时间系统到BDS周-周内秒的转换
        static private int[] bdsUTC2WeekWIS(DateTime bdsUTC)
        {                   
            return bdsNYR2WeekWIS(bdsUTC.AddSeconds(4));
        }
        ///功能模块五:GPS周-周内秒与BDS周-周内秒转换与逆转换///
        //GPS周-周内秒向BDS周-周周内秒的转换
        static private int[] gpsWeekWIS2bdsWeekWIS(int gpsWeek, int gpsWIS)
        {
            int[] bdsWeekWIS = {0,0};
            int difFromBegin = gpsWeek * 604800 + gpsWIS - 1356 * 604800 - 14;
            int bdsWeek = difFromBegin / 604800;
            int bdsWIS = difFromBegin % 604800;
            bdsWeekWIS[0] = bdsWeek;
            bdsWeekWIS[1] = bdsWIS;
            return bdsWeekWIS;
        }
        //BDS周-周内秒到GPS周-周内秒的转换
        static private int[] bdsWeekWIS2gpsWeekWIS(int bdsWeek, int bdsWIS)
        {
            int[] gpsWeekWIS = {0,0};
            int secDifGPS2BDS = bdsWeek * 604800 + bdsWIS + 1356 * 604800 + 14;
            int gpsWeek = secDifGPS2BDS / 604800;
            int gpsWIS = secDifGPS2BDS % 604800;
            gpsWeekWIS[0] = gpsWeek;
            gpsWeekWIS[1] = gpsWIS;
            return gpsWeekWIS;
        }
        static void Main(string[] args)
        {
            int[] gpsWeekWIS = { 2023, 432000};
            Console.Write("0 GPS周-周内秒:");
            Console.WriteLine("GPS周:{0:D},周内秒:{1:D}", gpsWeekWIS[0], gpsWeekWIS[1]);
            Console.Write("1.1 GPS周-周内秒对应日历时:");
            Console.WriteLine(gpsWeekWIS2NYR(gpsWeekWIS[0], gpsWeekWIS[1]));
            Console.Write("2.1 GPS周-周内秒对应UTC时:");
            Console.WriteLine(gpsWeekWIS2UTC(gpsWeekWIS[0], gpsWeekWIS[1]));
            Console.Write("5.1 GPS周-周内秒转BDS周-周内秒:");
            int[] bdsWeekWIS = gpsWeekWIS2bdsWeekWIS(gpsWeekWIS[0], gpsWeekWIS[1]);
            Console.WriteLine("北斗周:{0:D},周内秒: {1:D}", bdsWeekWIS[0], bdsWeekWIS[1]);
            Console.Write("3.1 BDS周-周内秒对应日历时:");
            Console.WriteLine(bdsWeekWIS2NYR(bdsWeekWIS[0], bdsWeekWIS[1]));
            Console.Write("4.1 BDS周-周内秒对应UTC时:");
            Console.WriteLine(bdsWeekWIS2UTC(bdsWeekWIS[0], bdsWeekWIS[1]));
            Console.Write("5.2 BDS周-周内秒转GPS周-周内秒:");
            int[] gpsWeekWISFromBDS = bdsWeekWIS2gpsWeekWIS(bdsWeekWIS[0], bdsWeekWIS[1]);
            Console.WriteLine("GPS周:{0:D},周内秒:{1:D}", gpsWeekWISFromBDS[0], gpsWeekWISFromBDS[1]);
            //日历时转GPS周-周内秒
            Console.Write("1.2 GPS年月日对应周-周内秒:");
            DateTime gpsNYR = new DateTime(2018, 10, 19, 0, 0, 0);
            int[] gpsWeekWISFromGpsNYR = gpsNYR2WeekWIS(gpsNYR);
            Console.WriteLine("GPS周:{0:D},周内秒:{1:D}", gpsWeekWISFromGpsNYR[0], gpsWeekWISFromGpsNYR[1]);
            //UTC时间系统转GPS周-周内秒
            Console.Write("2.2 UTC对应GPS周-周内秒:");
            DateTime gpsUTC = new DateTime(2018, 10, 18, 23, 59, 42);
            int[] gpsWeekWISFromGpsUTC = gpsUTC2WeekWIS(gpsUTC);
            Console.WriteLine("GPS周:{0:D},周内秒:{1:D}", gpsWeekWISFromGpsUTC[0], gpsWeekWISFromGpsUTC[1]);
            //日历时转BDS周-周内秒
            Console.Write("3.2 BDS年月日对应周-周内秒:");
            DateTime bdsNYR = new DateTime(2018, 10, 18, 23, 59, 46);
            int[] bdsWeekWISFrombdsNYR = bdsNYR2WeekWIS(bdsNYR);
            Console.WriteLine("bds周:{0:D},周内秒:{1:D}", bdsWeekWISFrombdsNYR[0], bdsWeekWISFrombdsNYR[1]);
            Console.Write("4.2 UTC对应bds周-周内秒:");
            DateTime bdsUTC = new DateTime(2018, 10, 18, 23, 59, 42);
            int[] bdsWeekWISFrombdsUTC = bdsUTC2WeekWIS(bdsUTC);
            Console.WriteLine("bds周:{0:D},周内秒:{1:D}", bdsWeekWISFrombdsUTC[0], bdsWeekWISFrombdsUTC[1]);
        }
    }
}

算例演示:

20181126094726943.png



相关文章
|
1月前
|
开发框架 前端开发 JavaScript
C# 6.0+JavaScript云LIS系统源码  云LIS实验室信息管理新型解决方案
云LIS是为区域医疗提供临床实验室信息服务的计算机应用程序,可协助区域内所有临床实验室相互协调并完成日常检验工作,对区域内的检验数据进行集中管理和共享,通过对质量控制的管理,最终实现区域内检验结果互认。其目标是以医疗服务机构为主体,以医疗资源和检验信息共享为目标,集成共性技术及医疗服务关键技术,建立区域协同检验,最大化利用有限的医疗卫生资源。
112 1
|
1月前
|
开发框架 前端开发 .NET
C#编程与Web开发
【4月更文挑战第21天】本文探讨了C#在Web开发中的应用,包括使用ASP.NET框架、MVC模式、Web API和Entity Framework。C#作为.NET框架的主要语言,结合这些工具,能创建动态、高效的Web应用。实际案例涉及企业级应用、电子商务和社交媒体平台。尽管面临竞争和挑战,但C#在Web开发领域的前景将持续拓展。
|
1月前
|
SQL 开发框架 安全
C#编程与多线程处理
【4月更文挑战第21天】探索C#多线程处理,提升程序性能与响应性。了解C#中的Thread、Task类及Async/Await关键字,掌握线程同步与安全,实践并发计算、网络服务及UI优化。跟随未来发展趋势,利用C#打造高效应用。
|
14天前
|
开发框架 前端开发 .NET
LIMS(实验室)信息管理系统源码、有哪些应用领域?采用C# ASP.NET dotnet 3.5 开发的一套实验室信息系统源码
集成于VS 2019,EXT.NET前端和ASP.NET后端,搭配MSSQL 2018数据库。系统覆盖样品管理、数据分析、报表和项目管理等实验室全流程。应用广泛,包括生产质检(如石化、制药)、环保监测、试验研究等领域。随着技术发展,现代LIMS还融合了临床、电子实验室笔记本和SaaS等功能,以满足复杂多样的实验室管理需求。
25 3
LIMS(实验室)信息管理系统源码、有哪些应用领域?采用C# ASP.NET dotnet 3.5 开发的一套实验室信息系统源码
|
22小时前
|
存储 C# 开发者
C# 编程基础:注释、变量、常量、数据类型和自定义类型
C# 编程基础:注释、变量、常量、数据类型和自定义类型
7 1
|
1月前
|
存储 运维 BI
基于C#-VC-MSSQL开发的全套PACS系统源码 3D PACS系统源码:可实现医学影像获取、存档、观片、处理、打印多项应用
PACS的功能价值在于通过连接不同的影像设备,存储与管理图像,图像的调用与后处理,实现资源共享,降低成本,达到提高工作效率、提升医疗水平的目地;
30 1
基于C#-VC-MSSQL开发的全套PACS系统源码  3D PACS系统源码:可实现医学影像获取、存档、观片、处理、打印多项应用
|
1月前
|
安全 API C#
C#.Net筑基-类型系统②常见类型--枚举Enum
枚举(enum)是C#中的一种值类型,用于创建一组命名的整数常量。它们基于整数类型(如int、byte等),默认为int。枚举成员可指定值,未指定则从0开始自动递增。默认值为0。枚举可以与整数类型互相转换,并可通过`[Flags]`特性表示位域,支持位操作,用于多选场景。`System.Enum`类提供了如`HasFlag`、`GetName`等方法进行枚举操作。
|
1月前
|
编译器 C#
C#.Net筑基-类型系统②常见类型 --record是什么类型?
`record`在C#中是一种创建简单、只读数据结构的方式,常用于轻量级数据传输。它本质上是类(默认)或结构体的快捷形式,包含自动生成的属性、`Equals`、`ToString`、解构赋值等方法。记录类型可以继承其他record或接口,但不继承普通类。支持使用`with`语句创建副本。例如,`public record User(string Name, int Age)`会被编译为包含属性、相等比较和`ToString()`等方法的类。记录类型提供了解构赋值和自定义实现,如密封的`sealed`记录,防止子类重写。
|
1月前
|
存储 C#
C#.Net筑基-类型系统②常见类型--结构体类型Struct
本文介绍了C#中的结构体(struct)是一种用户自定义的值类型,适用于定义简单数据结构。结构体可以有构造函数,能定义字段、属性和方法,但不能有终结器或继承其他类。它们在栈上分配,参数传递为值传递,但在类成员或包含引用类型字段时例外。文章还提到了`readonly struct`和`ref struct`,前者要求所有字段为只读,后者强制结构体存储在栈上,适用于高性能场景,如Span和ReadOnlySpan。
|
1月前
|
存储 安全 Unix
C#.Net筑基-类型系统②常见类型--日期和时间的故事
在System命名空间中,有几种表示日期时间的不可变结构体(Struct):DateTime、DateTimeOffset、TimeSpan、DateOnly和TimeOnly。DateTime包含当前本地或UTC时间,以及最小和最大值;DateTimeOffset增加了时区偏移信息,适合跨时区操作。UTC是世界标准时间,而格林尼治标准时间(GMT)不稳定,已被更精确的UTC取代。DateTimeOffset和DateTime提供了转换为UTC和本地时间的方法,以及各种解析和格式化函数。