首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在Python中查找任意给定年份的6月和12月的最后营业日期

在Python中查找任意给定年份的6月和12月的最后营业日期,通常需要考虑周末和可能的公共假期。以下是一个示例代码,它使用了pandas库来处理日期,并假设周末(周六和周日)不是营业日,同时考虑了公共假期。

基础概念

  • 日期处理:使用pandas库中的date_range函数来生成日期序列。
  • 公共假期:需要一个公共假期列表来排除这些日期。
  • 最后营业日期:找到6月和12月的最后一个营业日(非周末且不在公共假期中)。

示例代码

代码语言:txt
复制
import pandas as pd
from datetime import datetime

def get_last_business_day(year):
    # 假设的公共假期列表(示例)
    holidays = [
        datetime(year, 1, 1),  # 元旦
        datetime(year, 12, 25),  # 圣诞节
        # 添加其他公共假期...
    ]
    
    # 定义一个函数来检查是否是营业日
    def is_business_day(date):
        return date.weekday() < 5 and date not in holidays
    
    # 查找6月和12月的最后营业日期
    last_business_day_june = None
    last_business_day_december = None
    
    for month in [6, 12]:
        # 生成该月的所有日期
        dates_in_month = pd.date_range(start=f"{year}-{month}-01", end=f"{year}-{month+1}-01", closed='left')
        
        for date in reversed(dates_in_month):
            if is_business_day(date):
                if month == 6:
                    last_business_day_june = date
                elif month == 12:
                    last_business_day_december = date
                break
    
    return last_business_day_june, last_business_day_december

# 示例使用
year = 2023
june_last_business_day, december_last_business_day = get_last_business_day(year)
print(f"2023年6月的最后营业日期是: {june_last_business_day}")
print(f"2023年12月的最后营业日期是: {december_last_business_day}")

优势

  • 灵活性:可以轻松调整公共假期列表以适应不同的国家和地区。
  • 准确性:通过遍历日期并检查每个日期是否为营业日,确保找到准确的最后营业日期。

类型

  • 日期处理工具:使用pandas库进行高效的日期操作。
  • 自定义逻辑:通过定义is_business_day函数来处理特定的营业日规则。

应用场景

  • 财务报告:需要知道特定月份的最后一个营业日来准备财务报告。
  • 项目管理:安排项目里程碑时需要考虑最后一个营业日。
  • 自动化任务:在自动化系统中安排任务执行时间。

可能遇到的问题及解决方法

  1. 公共假期列表不完整:确保公共假期列表是最新的,并且包含所有相关的假期。
  2. 时区问题:如果需要处理不同时区的日期,可以使用pytz库来管理时区。
  3. 性能问题:对于非常大的日期范围,可以考虑优化代码以提高性能。

通过上述方法和代码示例,可以有效地找到任意给定年份的6月和12月的最后营业日期。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

python 在排序数组中查找元素的第一个和最后一个位置 多种解法

二分查找:基于二分查找的算法可以在 O(log n) 的时间复杂度内解决该问题。具体实现方式是,先使用二分查找找到该元素的位置,然后向左和向右扩展,直到找到第一个和最后一个位置。...target and nums[rightIdx] == target: return [leftIdx, rightIdx] return [-1, -1] 线性扫描:线性扫描的思路是从左到右遍历数组...,记录第一次出现目标值的位置,然后继续遍历数组,直到找到最后一次出现目标值的位置,代码如下: def searchRange(nums, target): first, last = -1, -...if first == -1: first = i last = i return [first, last] 使用 Python...内置函数:Python 中有内置函数 bisect_left 和 bisect_right 可以帮助我们实现二分查找。

8310

在排序数组中查找元素的第一个和最后一个位置

在排序数组中查找元素的第一个和最后一个位置 给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。...接下来,在去寻找左边界,和右边界了。 采用二分法来去寻找左右边界,为了让代码清晰,我分别写两个二分来寻找左边界和右边界。...刚刚接触二分搜索的同学不建议上来就像如果用一个二分来查找左右边界,很容易把自己绕进去,建议扎扎实实的写两个二分分别找左边界和右边界 寻找右边界 先来寻找右边界,至于二分查找,如果看过704.二分查找就会知道...总结 初学者建议大家一块一块的去分拆这道题目,正如本题解描述,想清楚三种情况之后,先专注于寻找右区间,然后专注于寻找左区间,左右根据左右区间做最后判断。...nums 数组中二分查找得到第一个大于等于 target的下标leftBorder; # 2、在 nums 数组中二分查找得到第一个大于等于 target+1的下标, 减1则得到rightBorder;

4.7K20
  • 在排序数组中查找元素的第一个和最后一个位置

    前言: 这是一道给很经典的二分查找题目,并且该二分查找的算法不同于简单二分,是二分查找的进阶版本。 一、题目描述 34....在排序数组中查找元素的第一个和最后一个位置 给你一个按照非递减顺序排列的整数数组 nums,和一个目标值 target。请你找出给定目标值在数组中的开始位置和结束位置。...如果数组中不存在目标值 target,返回 [-1, -1]。 你必须设计并实现时间复杂度为 O(log n) 的算法解决此问题。...第二步就是普通二分算法的代码 注意这里有一个细节,跟普通二分查找算法不同,也是后面细节的“万恶之源”。...总结:只要左式和右式的操作数不一样,中点就偏向哪边!!!

    10410

    Leetcode No.34 在排序数组中查找元素的第一个和最后一个位置

    一、题目描述 给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。 如果数组中不存在目标值 target,返回 [-1, -1]。...,返回下标mid 5、当目标值小于等于nums[mid]时,说明目标值在左侧,往左侧递归查找,否则往右侧递归查找 查找最后一个位置同理,唯一不同的是第4、5步 4、假如nums[mid]等于target...且nums[mid]比相邻的右侧元素小,返回下标mid ​5、当目标值大于等于nums[mid]时,说明目标值在右侧,往右侧递归查找,否则往左侧递归查找 三、代码 package search_range...mid]<nums[mid+1]){ return mid; } if(target>=nums[mid]){ //寻找最后一个位置...二分查找的时间复杂度为 O(logn),一共会执行两次,因此总时间复杂度为O(logn)。 空间复杂度:O(1) 。只需要常数空间存放若干变量。

    1.9K10

    leetcode-34-在排序数组中查找元素的第一个和最后一个位置

    题目描述: 给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。 你的算法时间复杂度必须是 O(log n) 级别。...: vector searchRange(vector& nums, int target)  说明: 1、这道题给定一个vector和一个target,vector中装着升序的一个数组...,比如[5,7,7,8,8,10], 要求找到target比如8,在vector中的起始位置和结束位置。...按照二分法的思路,我们可以这样子设计: ①首先根据二分法找到vector中的某个target元素,这个元素是一串target元素中的某一个,记这个元素的索引是med。...这个元素的前一个元素,也就是一串target元素中的最后一个。

    3.5K40

    leetcode34-在排序数组中查找元素的第一个和最后一个位置

    前言 今天刷的题目是:在排序数组中查找元素的第一个和最后一个位置,这道题目在最开始AC以后,然后做了两步的优化操作,供大家参考。...题目 leetcode-34:在排序数组中查找元素的第一个和最后一个位置 分类(tag):二分查找这一类 英文链接:https://leetcode.com/problems/find-first-and-last-position-of-element-in-sorted-array...找出给定目标值在数组中的开始位置和结束位置。 你的算法时间复杂度必须是 O(log n) 级别。 如果数组中不存在目标值,返回 [-1, -1]。...,前面已经讲过了二分查找,(二分查找:RNG输了,但我们不能输)这里不再继续讲,讲一下代码23行到24行,leftIndex就是我之前说的保存这个已经找的的下标,24行就是因为是找最最左边的下标,所以把...-1,如果不是-1,那说明需要继续找最右边的下标,如果是-1的话,那么说明数组中没有target的值,所以我们也不必在去找最右边的下标了,因为已经找过了,不存在的,还费这事干嘛,最终这样优化完速度快了1ms

    2.6K30

    LeetCode-34-在排序数组中查找元素的第一个和最后一个位置

    # LeetCode-34-在排序数组中查找元素的第一个和最后一个位置 给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。...你的算法时间复杂度必须是 O(log n) 级别。 如果数组中不存在目标值,返回 [-1, -1]。...,如果找完了都没有找到,返回[-1,-1] 移动尾指针,直到找到最后一个等于target的位置,如果找完了都没有找到,返回[-1,-1] 当头尾指针相同时,说明只有一个target,返回当前位置[start...,start]或[end,end] 反之,返回头尾指针区间[start,end] 方法2、二分查找(fast): 通过判断mid位置的数值,决定左右边界的移动 当nums[mid]查找另外一个边界等于target的即可,可以进行循环移动查找,最后返回[start,end]即可 如果没有找到,返回[-1,-1] 方法3、递归分治(low): 通过二分查找切分数组寻找左右子数组的

    2.3K20

    在排序数组中查找元素的第一个和最后一个位置(leetcode34)

    给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。 如果数组中不存在目标值 target,返回 [-1, -1]。...示例 1: 输入:nums = [5,7,7,8,8,10], target = 8 输出:[3,4] 解析: 方法一:二分查找 二分查找中,寻找leftIdx 即为在数组中寻找第一个大于等于 target...的下标,寻找 rightIdx 即为在数组中寻找第一个大于target 的下标,然后将下标减一。...两者的判断条件不同,为了代码的复用,我们定义 binarySearch(nums, target, lower) 表示在 nums 数组中二分查找 target 的位置,如果 lower 为 true,...则查找第一个大于等于 target 的下标,否则查找第一个大于target 的下标。

    1.8K10

    LeetCode题目34:在排序数组中查找元素的第一个和最后一个位置

    原题描述 + 给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。 你的算法时间复杂度必须是 O(log n) 级别。...,提示了我们使用二分查找的解法。...普通的二分查找在找到target后立即返回,所以我们需要做变式,情况分为以下两种。 寻找左边界 还是得举个例子。...因为lower的左边不是target,而higher也一直在尽可能的往左挪动。 寻找右边界 与上面过程相反,我们尽可能向右挪动lower,让其与higher相撞即可。...但如果复用上面的逻辑,每次挪动时令lower=mid+1,那么最终lower一定会与higher相撞于最后一个target的后一个位置。此时lower-1才是所求。

    3.1K20

    在排序数组中查找元素的第一个和最后一个位置

    前言 今天主要讲解的内容是:如何在已排序的数组中查找元素的第一个和最后一个位置。以 leetcode 34 题作为例题,提供二分查找的解题思路,供大家参考。...题目详述 给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。 如果数组中不存在目标值 target,返回 [-1, -1]。...同查找元素的第一个位置类似,在查找到数组中某元素值等于目标值 target 时,不立即返回,通过增大查找区间的下边界 low (令 low = mid + 1),不断向 mid 的右侧收缩,最后达到锁定右边界...查找元素的第一个和最后一个位置代码: // C语言版本 int GetTargetPosition(int* nums, int numsSize, int target, int locFlag)...if (nums == NULL || numsSize < 1) { return res; } /* 通过 locFlag 标志区分查找的元素的位置在一个还是最后一个

    2.6K20

    LeetCode - #34 在排序数组中查找元素的第一个和最后一个位置(Top 100)

    微博:@故胤道长[1]**)的 Swift 算法题题解整理为文字版以方便大家学习与阅读。...LeetCode 算法到目前我们已经更新了 33 期,我们会保持更新时间和进度(周一、周三、周五早上 9:00 发布),每期的内容不多,我们希望大家可以在上班路上阅读,长久积累会有很大提升。...如果大家有建议和意见欢迎在文末留言,我们会尽力满足大家的需求。 难度水平:中等 1. 描述 给定一个按照升序排列的整数数组 nums,和一个目标值 target。...找出给定目标值在数组中的开始位置和结束位置。 如果数组中不存在目标值 target,返回 [-1, -1]。 进阶: 你可以设计并实现时间复杂度为 O(log n) 的算法解决此问题吗? 2....时间复杂度: O(logn) 空间复杂度: O(1) 该算法题解的仓库:LeetCode-Swift[2] 点击前往 LeetCode[3] 练习 特别感谢 Swift社区 编辑部的每一位编辑,感谢大家的辛苦付出

    1.5K20
    领券