在C#中如何自定義配置上周和本周起始日來查詢業務數據?

来源:https://www.cnblogs.com/kimiliucn/archive/2023/09/19/17715464.html
-Advertisement-
Play Games

在做某個報表管理功能時,有一個需求:需要根據自定義配置的[周起始日]來統計上周、本周的訂單數據。在C#中並沒有封裝的方法根據我們需要來直接獲取上一周某天到某天、本周某天到某天,所以需要我們自己封裝方法來實現(我們也可以按照這個思路使用其他語言來實現)。 ...


cover.png

作者:西瓜程式猿
主頁傳送門:https://www.cnblogs.com/kimiliucn


前言

在做某個報表管理功能時,有一個需求:需要根據自定義配置的[周起始日]來統計上周、本周的訂單數據。在C#中並沒有封裝的方法根據我們需要來直接獲取上一周某天到某天、本周某天到某天,所以需要我們自己封裝方法來實現(我們也可以按照這個思路使用其他語言來實現)。


一、需求與思路

需求是這樣的,我們需要根據自定義配置的[周起始日]來統計上周、本周的訂單數據,具體看下文介紹。

1.1-需求介紹

舉個例子:假設今天是【2023年9月19日(星期二)】,若配置的是【周一】,那麼上周要查詢的時間是從上周一計數到上周日(2023年9月11日——2023年9月17日),那麼本周要查詢的時間是本周一計數到本周日(2023年9月18日——2023年9月24日)。
image.png
若配置的是【周日】,那麼上周要查詢的時間是從上上周日計數到上周六(2023年9月10日——2023年9月16日),那麼本周要查詢的時間是上周日計數到本周六(2023年9月17日——2023年9月23日)。【註意:因為上文假設今天是2023年9月19日(星期二),而配置的是(星期日),當還未到這一天,所有需要取離最近的上一周的星期日】
image.png
另外一個場景,如果假設今天是【2023年9月24日(星期日)】,若配置的是【周日】,那麼上周要查詢的時間是從上周日計數到本周六(2023年9月17日——2023年9月23日),那麼本周要查詢的時間是上周日計數到本周六(2023年9月24日——2023年9月30日)。
image.png


1.2-開發思路

第一步:首先新建了一個配置表,來存儲我們配置的是星期幾,[西瓜程式猿]這邊存的是字元串數字(1-7),1表示星期一,2表示星期二,7表示星期日,以此類推。


第二步【核心】:根據配置的[周起始日]來計算出,上一周要查詢的數據從哪一天開始到哪一天結束,本周要查詢的數據應該從哪一天開始到哪一天結束(本文代碼演示主要就是介紹這一塊邏輯)。


第三步:根據計算出來的開始/結束日期,來根據[訂單創建的時間](根據自己業務需求)來和計算出來的日期判斷即可。


二、代碼實現

2.1-封裝

        /// <summary>
        /// 獲得上周、本周配置時間(用於讀取數據)
        /// </summary>
        /// <param name="startWeekDay">配置的[周起始日]</param>
        /// <param name="now">當前時間</param>
        /// <returns></returns>
        public (string upper_week_begin, string upper_week_end, string this_week_begin, string this_week_end) GetWeekTimeStr(int startWeekDay, DateTime now)
		{
			if (startWeekDay <  1 || startWeekDay > 7)
			{
                throw new ArgumentOutOfRangeException(nameof(startWeekDay), "startWeekDay must be between 1 and 7.");
            }
            int currentDayOfWeek = (int)now.DayOfWeek;//獲取當前日期為星期幾
            DateTime currentDate = DateTime.Now.Date; //獲取到當前日期
            string upper_week_begin, upper_week_end, this_week_begin, this_week_end;
            //如果配置的星期 大於 當前星期
            if (startWeekDay > currentDayOfWeek || startWeekDay == currentDayOfWeek)
            {
                DayOfWeek week = DayOfWeek.Monday;
                switch (startWeekDay)
                {
                    case 1: week = DayOfWeek.Monday; break;
                    case 2: week = DayOfWeek.Tuesday; break;
                    case 3: week = DayOfWeek.Wednesday; break;
                    case 4: week = DayOfWeek.Thursday; break;
                    case 5: week = DayOfWeek.Friday; break;
                    case 6: week = DayOfWeek.Saturday; break;
                    case 7: week = DayOfWeek.Sunday; break;
                    default:
                        break;
                }
                DateTime lastThursday = GetDayOfWeek(currentDate, week);//本周的開始日期
                DateTime lastWeekSunday = lastThursday.AddDays(6);//本周的結束日期,根據[本周開始日期]往後推6天
                DateTime lastLastThursday = GetDayOfWeek(lastThursday.AddDays(-1), week);//根據本周的開始時間,往前推1天,找到上一周的開始時間
                DateTime lastLastWeekSunday = lastLastThursday.AddDays(6);//上一周的結束時間

                upper_week_begin = lastLastThursday.ToString("yyyy-MM-dd");
                upper_week_end = lastLastWeekSunday.ToString("yyyy-MM-dd");
                this_week_begin = lastThursday.ToString("yyyy-MM-dd");
                this_week_end = lastWeekSunday.ToString("yyyy-MM-dd");
            }
            else
            {
                //返回本周和上周的開始和結束日期
                DateTime thisWeekMonday = GetDayOfWeek(now, DayOfWeek.Monday);//本周的開始日期
				DateTime thisWeekSunday = thisWeekMonday.AddDays(6); //本周的結束日期,根據[本周開始日期]往後推6天
                DateTime lastWeekMonday = thisWeekMonday.AddDays(-7);//根據[本周開始日期],往前推7天,得到[上周開始時間]
                DateTime lastWeekSunday = thisWeekMonday.AddDays(-1);//根據[本周的開始日期],往前推1天,得到[上周結束時間]

                upper_week_begin = lastWeekMonday.ToString("yyyy-MM-dd");
                upper_week_end = lastWeekSunday.ToString("yyyy-MM-dd");
                this_week_begin = thisWeekMonday.ToString("yyyy-MM-dd");
                this_week_end = thisWeekSunday.ToString("yyyy-MM-dd");
            }
			return (upper_week_begin, upper_week_end, this_week_begin, this_week_end);
        }

        /// <summary>
        /// 獲取上一個指定星期的日期
        /// </summary>
        /// <param name="date"></param>
        /// <param name="targetDayOfWeek"></param>
        /// <returns></returns>
        public static DateTime GetDayOfWeek(DateTime date, DayOfWeek targetDayOfWeek)
        {
            int diff = (7 + (date.DayOfWeek - targetDayOfWeek)) % 7;
            return date.AddDays(-diff).Date;
        }

2.2-使用

var item = GetWeekTimeStr(startWeekDay, now);
// 取出數據
if (!string.IsNullOrEmpty(item.upper_week_begin))
{

}
if (!string.IsNullOrEmpty(item.upper_week_end))
{
   
}
if (!string.IsNullOrEmpty(item.this_week_begin))
{
   
}
if (!string.IsNullOrEmpty(item.this_week_end))
{
    
}

然後根據查詢出來的時間段,應用到自己需要的業務場景即可。



原文鏈接:https://www.cnblogs.com/kimiliucn/p/17715464.html

版權聲明:本文為原創文章,版權歸 [西瓜程式猿] 所有,轉載請註明出處,有任何疑問請私信咨詢。
原文鏈接:https://www.cnblogs.com/kimiliucn/p/17715464.html

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • OpenHarmony Meetup 常州站正火熱招募中! 誠邀充滿激情的開發者參與線下盛會~ 探索OpenHarmony前沿科技,暢談未來前景, 感受OpenHarmony生態構建之路的魅力! 線下參與,名額有限,僅限20位幸運者! 報名截止時間為9月26日24:00點,快快行動起來~ 參加Ope ...
  • 一. gcc 安裝 yum install gcc-c++ 安裝 nginx 需要先將官網下載的源碼進行編譯,編譯依賴 gcc 環境,如果沒有 gcc 環境,則需要安裝: cd /etc/yum.repos.d/ sed -i 's/mirrorlist/#mirrorlist/g' /etc/yu ...
  • 基於java高校獎學金管理系統設計與實現,可適用於大學獎學金管理系統,學生獎學金管理系統,學校獎學金,校園獎學金申請管理系統; ...
  • 除了繪製各類分析圖形(比如柱狀圖,折線圖,餅圖等等)以外,matplotlib 也可以在畫布上任意繪製各類幾何圖形。這對於電腦圖形學、幾何演算法和電腦輔助設計等領域非常重要。 matplitlib 中的 patches 類提供了豐富的幾何對象,本篇拋磚引玉,介紹其中幾種常用的幾何圖形繪製方法。 其 ...
  • 截至目前(2023年),Java8發佈至今已有9年,2018年9月25日,Oracle發佈了Java11,這是Java8之後的首個LTS版本。那麼從JDK8到JDK11,到底帶來了哪些特性呢?值得我們升級嗎?而且升級過程會遇到哪些問題呢?帶著這些問題,本篇文章將帶來完整的JDK8升級JDK11最全實... ...
  • 用Rust手把手編寫一個Proxy(代理), 動工 項目 ++wmproxy++ gitee 傳送門 github 傳送門 設計流程圖 flowchart LR A[客戶端] -->|Http| B[代理端] --> C[代理服務端] --> D[服務端] B -->|直達| D A -->|Htt ...
  • 在學習C#中的記錄類型時,對出現的Equals和ReferenceEquals得到的不同結果表示不理解,隨即進行相關資料查找。 值類型 == : 比較兩者的“內容”是否相同,即“值”是否一樣Equals:比較兩者的“內容”是否相同,即“值”是否一樣ReferenceEquals:返回false,因為 ...
  • 生成者/消費者概念編程模型 通道是生成者/使用者概念編程模型的實現。 在此編程模型中,生成者非同步生成數據,使用者非同步使用該數據。 換句話說,此模型將數據從一方移交給另一方。 嘗試將通道視為任何其他常見的泛型集合類型,例如 List。 主要區別在於,此集合管理同步,並通過工廠創建選項提供各種消耗模型。 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...