首页 > 编程语言 >C#获得项目最后编译时间

C#获得项目最后编译时间

时间:2024-02-05 23:45:15浏览次数:36  
标签:ch string 项目 C# System 编译 OriginVersion

C#获得项目最后编译时间

效果

具体格式可以自定义

核心代码

string GetCompileVersion()
{
    string OriginVersion = "" + System.IO.File.GetLastWriteTime(this.GetType().Assembly.Location);
    int MsgCnt = 0;
    string year = "";
    string month = "";
    string day = "";
    string hour = "";
    string min = "";
    string sec = "";
    for (int i = 0; i < OriginVersion.Length && MsgCnt < 6; i++)
    {
        char ch = OriginVersion[i];
        if (ch >= '0' && ch <= '9')
        {
            switch (MsgCnt)
            {
                case 0: year += ch; break;
                case 1: month += ch; break;
                case 2: day += ch; break;
                case 3: hour += ch; break;
                case 4: min += ch; break;
                case 5: sec += ch; break;
            }
        }
        else
        {
            MsgCnt++;
        }
    }
    while (year.Length < 4) year = "0" + year;
    while (month.Length < 2) month = "0" + month;
    while (day.Length < 2) day = "0" + day;
    while (hour.Length < 2) hour = "0" + hour;
    while (min.Length < 2) min = "0" + min;
    while (sec.Length < 2) sec = "0" + sec;
    return year + month + day + hour + min + sec;
}

使用

public MainWindow()
{
    InitializeComponent();
    CompileTime.Text = GetCompileVersion();
}

原理

  1. 使用 System.IO.File.GetLastWriteTime 方法获取程序集文件(即 .dll.exe 文件)的最后修改时间——可以间接反映程序集的最后编译时间。
  2. 定义六个字符串变量 yearmonthdayhourminsec,用于存储相应的日期和时间组件。
  3. 通过一个 for 循环遍历 OriginVersion 字符串中的每个字符。如果字符是数字(介于 '0' 和 '9' 之间),则根据当前的 MsgCnt 值将数字字符追加到相应的变量中。
  4. 若长度不足其应有的长度(年4位,其他都是2位),则在它们的前面添加 '0'。
  5. 最后,将所有这些组件串联起来,形成一个格式为 yyyyMMddHHmmss 的字符串。

参考

DateTime 结构 (System) | Microsoft Learn

C#获取编译时间作为版本_c# 获取编译时间-CSDN博客

标签:ch,string,项目,C#,System,编译,OriginVersion
From: https://www.cnblogs.com/Vanilla-chan/p/18009017/CSharp_Getting_Last_Compilation_Time

相关文章

  • Reinforcement Learning Chapter2
    本文参考《ReinforcementLearning:AnIntroduction(2ndEdition)》SuttonK臂赌博机问题描述:你有k个选择,每个选择对应一个奖励,收益由所选动作决定的平稳概率分布产生,目标为最大化某段时间内的总收益期望。联系我们在chapter1中提到的reward,value,action等概念,我们在这个K臂赌博机......
  • 【板子】费用流(zkw/Dinic)
    //lgp3381#include<bits/stdc++.h>usingnamespacestd;#definelllonglongconstintN=(int)5e3+3;constintM=(int)5e4+4;constllINF=0x3f3f3f3f;intcur[N];lldis[N];boolvis[N];boolinq[N];intedgeid=1;inthead[N];structedge{in......
  • css的使用
    font连写font-style设置文字是否倾斜font-weight设置文字是否加粗font-family设置文字类型,例如宋体文字连写格式:{font:font-stylefont-weightfont-sizefont-family}例如:p{font:normol70020px"宋体"}text-decoration设置文本划线位置(a标签一般会去掉下划线)underline设......
  • web-service(JAX-WS)
    1.分类1>JAX-WS2>JAX-RSJAX-RS是java针对REST(RepresentationStateTransfer)风格制定的一套web服务器规范 开发步骤:1.ideal上创建空项目--->点击ok创建目录--->Modules--->quickstart,如下图--->next--->项目名称  2.添加依赖  ......
  • 2.5 響け恋の歌 ——ARC107~109
    我猜是小小恋歌赞助了这个系列!由于懒得再把细节回想一遍所以会比较概括。但是总体做法保真。ARC107DNumberofMultisets考虑DP:\(f(i,j)\)表示\(i\)个数凑成\(j\)的方案数。那么我们可以枚举最大数的幂次,容易发现只是\(O(\logn)\)的。然后枚举了之后发现是一个类似......
  • 2.4 響け恋の歌 ——ARC古报 104~106
    本来想一次放五场的,但是感觉实在是太多了,题解写起来很累,就改为三场了。以后没活了就写这个。ARC多的是,所以近阶段就不会没活啦!ARC104DMultisetMean对于\(x\),我们只需要求出\([0,x-1]\)的元素组合的背包,以及\([1,n-x]\)的元素组合的背包,然后再做点乘即可。做背包的时候......
  • C++编程练习||实现分数类Fraction1、实现分数的+,-,*,/ 2、逻辑运算==、!=、<、<=、>、>
    题目:实现分数类Fraction  classFraction{   intnumerator,denominator;   public:   ....  };  要求:1、实现分数的+,-,*,/2、逻辑运算==、!=、<、<=、>、>=6种运输符号。3、实现输出<<,输入 >>操作符重载。  样例1输入:   12 ......
  • ReentrantLock源码分析、LockSuppor、ReentrantReadWriteLock、锁优化的方法
    ReentrantLock类图我们看一下重入锁ReentrantLock类关系图,它是实现了Lock接口的类。NonfairSync和FairSync都继承自抽象类Sync,在ReentrantLock中有非公平锁NonfairSync和公平锁FairSync的实现。在重入锁ReentrantLock类关系图中,我们可以看到NonfairSync和FairSync都继承自抽象......
  • ReentrantLock源码分析、LockSuppor、ReentrantReadWriteLock、锁优化的方法
    ReentrantLock类图我们看一下重入锁ReentrantLock类关系图,它是实现了Lock接口的类。NonfairSync和FairSync都继承自抽象类Sync,在ReentrantLock中有非公平锁NonfairSync和公平锁FairSync的实现。在重入锁ReentrantLock类关系图中,我们可以看到NonfairSync和FairSync都继承自抽象......
  • WC2024 水镜
    洛谷传送门WC2024被打爆了,呜呜。我赛时会这题\(8\)分指数级暴力,哈哈。真不知道自己在干嘛。下文令\(T=2L\)。考虑如何判定一个序列\(a\)是否合法。考虑先枚举一个\(T\)。因为要求\(r_i<r_{i+1}\),考虑讨论相邻两项的取值:若\(a_i<a_{i+1}\)则\(r_i=a_i,......