百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

DAY6-step7 Python 示例说明CALENDAR

yuyutoo 2024-11-18 18:58 3 浏览 0 评论

Python中的Calendar模块具有Calendar类,该类允许基于日期,月份和年份来计算各种任务。 最重要的是,Python中的TextCalendar和HTMLCalendar类允许您编辑日历并根据需要使用。

让我们看看如何使用Python日历。

步骤1)运行代码。

  • 代码行1:我们从“导入日历”开始,它将导入此模块的所有类。
  • 代码行3:c = calendar.TextCalendar(calendar.SUNDAY)告诉解释器创建文本日历。 这个月的开始是星期日。 在Python中,您可以设置日历的格式,因为您可以更改月份的开始日期
  • 代码行4:str = c.formatmonth(2025,1)我们正在创建2025年的日历,即月1 – 1月
  • 第5行代码:print str将打印输出。

让我们快速将值从周日更改为周四并检查输出

第2步)您还可以将HTML格式的日历打印出来,如果开发人员希望对日历的外观和风格进行任何更改,此函数对开发人员很有帮助

步骤3)使用c.itermonthday(2025,4)在一个月的天中循环,它将获取该月的总天数。

  • 当您执行代码以获取特定月份的总天数时,说出“ April”,那么您将获得30天的输出,但是在开始的时候(有时是在结尾),您也会看到一些零。 。
  • 输出中的零表示一周中的某天是一个重叠的月份,这意味着它不属于该月份。
  • 这些零出现在输出中是因为在您的代码中提到了天(星期四),因此,当您调用函数“ c.itermonthdays”时,它将开始计算从星期四开始的天数,而您的星期四可能不是从4月1日开始的3月28日或3月29日,因此当您执行代码时,它将开始计算从3月28日开始的天数,以及从3月28日到4月1日的任何天数。这些天将被计为零,并且在输出中您将看到这些零,并且对月末也是如此。
  • 因此,除了日期1-30外,上个月和下个月的所有日期将在输出中显示为零。

步骤4)您可以从本地系统中获取数据,例如月份或工作日等

  • 此处的输出显示我们已经从本地系统打印出月份名称。 同样,您也可以获取工作日名称,如下所示
  • 输出将取决于本地系统,假设您的本地系统是其他国家/地区,则它将根据该国家/地区的本地设置给出输出。 在这里,我们有几个月的时间,所以不会有什么区别,但是如果是一周或一天,则肯定会有所不同。

步骤5)您可以获取全年特定日期的列表。 例如,一周的每个第一个星期一都有一个审核日。 您想知道每个月的第一个星期一的日期。 您可以使用此代码

  • mycal = calendar.monthcalendar(2025,month)将创建该月份的日历
  • 将变量week1和week2设置为日历的第一周和第二周
  • 检查第1周是否包含星期一,设置审核日
  • 否则将审核日设置为第2周的第一个星期一
  • 输出显示该月的第一个星期一的日期。
  • 该Cal对象的长度将确定为一定长度,具体取决于一个月中有多少周。在我们的情况下,它将是一两个,因为一周的第一个星期一通常会在第一周,但如果没有,则考虑第二周。让我们详细了解为什么我们还要考虑第二周。
  • 在这里,我们使用日历的常量星期一,日历对象为您提供代表星期日,星期一,星期二等的常量。我们以前已经看过这些。因此,如果在一周的第一天,星期一常量表示的天不等于0,请记住零表示属于另一个月的天。因此,在这种情况下,如果它为零,那么它将是属于上个月的星期一。但是,如果第一个星期一不等于0,则意味着我的审核日将在一周之内。否则,如果该值为0,则第一个星期一不在该月的第一个星期,而必须在第二个星期。
  • 因此,然后我说好,将我的审核日变量设置为第二周代表的星期一。因此,无论是第一周还是第二周,审计日都会回来。

这是完整的代码

Python 2 Example

import calendar
# Create a plain text calendar
c = calendar.TextCalendar(calendar.THURSDAY)
str = c.formatmonth(2025, 1, 0, 0)
print str

# Create an HTML formatted calendar
hc = calendar.HTMLCalendar(calendar.THURSDAY)
str = hc.formatmonth(2025, 1)
print str
# loop over the days of a month
# zeroes indicate that the day of the week is in a next month or overlapping month
for i in c.itermonthdays(2025, 4):
    print i

    # The calendar can give info based on local such a names of days and months (full and abbreviated forms)
    for name in calendar.month_name:
        print name
    for day in calendar.day_name:
        print day
    # calculate days based on a rule: For instance an audit day on the second Monday of every month
    # Figure out what days that would be for each month, we can use the script as shown here
    for month in range(1, 13):
		# It retrieves a list of weeks that represent the month
        mycal = calendar.monthcalendar(2025, month)
		# The first MONDAY has to be within the first two weeks
        week1 = mycal[0]
        week2 = mycal[1]
        if week1[calendar.MONDAY] != 0:
            auditday = week1[calendar.MONDAY]
        else:
        # if the first MONDAY isn't in the first week, it must be in the second week
        	auditday = week2[calendar.MONDAY]
print "%10s %2d" % (calendar.month_name[month], auditday)
       

Python 3 Example

import calendar
# Create a plain text calendar
c = calendar.TextCalendar(calendar.THURSDAY)
str = c.formatmonth(2025, 1, 0, 0)
print(str)

# Create an HTML formatted calendar
hc = calendar.HTMLCalendar(calendar.THURSDAY)
str = hc.formatmonth(2025, 1)
print(str)
# loop over the days of a month
# zeroes indicate that the day of the week is in a next month or overlapping month
for i in c.itermonthdays(2025, 4):
    print(i)

    # The calendar can give info based on local such a names of days and months (full and abbreviated forms)
    for name in calendar.month_name:
        print(name)
    for day in calendar.day_name:
        print(day)
    # calculate days based on a rule: For instance an audit day on the second Monday of every month
    # Figure out what days that would be for each month, we can use the script as shown here
    for month in range(1, 13):
		# It retrieves a list of weeks that represent the month
        mycal = calendar.monthcalendar(2025, month)
		# The first MONDAY has to be within the first two weeks
        week1 = mycal[0]
        week2 = mycal[1]
        if week1[calendar.MONDAY] != 0:
            auditday = week1[calendar.MONDAY]
        else:
        # if the first MONDAY isn't in the first week, it must be in the second week
        	auditday = week2[calendar.MONDAY]
print("%10s %2d" % (calendar.month_name[month], auditday))
        

摘要:

  • 在Python中,可以更改日历的格式,因为您可以更改开始的月份日期
  • 以HTML格式打印出日历
  • 从本地系统中获取数据,例如几个月或工作日
  • 获取全年特定日期的列表

相关推荐

MySQL中的数据类型(mysql数据类型有哪些,并举例)

MySQL中的数据类型...

mysql窗口函数over中rows_MySQL窗口函数

下面的讲解将基于这个employee2表:mysql>SELECT*FROMemployee2;+----+-----------+------+---------+---------...

别再说你精通数据库,MySQL的设计和列类型选取真的很有讲究

总想写一篇MySQL的设计和列类型选取的文章,一直挤不出时间。天天晚上都要加班,正逢5.1放假,抽了几天就有了此文。如果对朋友们能有帮助的话,关注一波不过分吧?求关!选择更优的数据类型尽量选择存储空间...

MySQL数据库知识(mysql数据库相关知识)

MySQL是一种关系型数据库管理系统;那废话不多说,直接上自己以前学习整理文档:查看数据库命令:(1).查看存储过程状态:showprocedurestatus;(2).显示系统变量:show...

数据库:MySQL 高性能优化规范建议

数据库命令规范所有数据库对象名称必须使用小写字母并用下划线分割所有数据库对象名称禁止使用MySQL保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来)数据库对象的命名要能做到见名识意,...

MySQL实战——表结构设计之数字类型

整型不建议刻意去用unsigned属性,因为在做一些数据分析时,SQL可能返回的结果并不是想要得到的结果。比如在财务的场景下,经常会做一些加减操作。MySQL要求unsigned数值相减之...

MySQL数据库入门(四)数据类型简介

在MySQL中数据类型有以下五种:数字整数:常用的有2种,一是int型,int型最多可以表示10位数字(无符号的4开头,有符号的2开头;二是tinyintunsigned,用来表示年龄(值范围是0-...

mysql常用语句超级详细汇总(mysql常用语法)

1.连接数据库:连接本地数据库:mysql-uroot-p连接远程数据库:mysql-h192.169.22.199-uroot-p退出数据库:exit...

MYSQL——CAST()函数的用法(mysql中case)

语法为:Cast(字段名as转换的类型),其中类型可以为:CHAR[(N)]字符型DATE日期型DATETIME日期和时间型...

MySQL存储引擎背后的真相:为何InnoDB并非所有场景的最佳选择

MySQL存储引擎背后的真相:为何InnoDB并非所有场景的最佳选择引言部分你是否遇到过这样的情况:明明已经按照最佳实践选择了MySQL的InnoDB引擎,却发现某些查询依然缓慢得令人沮丧?或者当你的...

MySQL 表分区?涨知识了(mysql数据表分区)

1.什么是表分区...

《MySQL必知必会》_笔记08(mysql必知必会mobi)

第19章插入数据一、数据插入概述INSERT语句用于向数据库表中插入(添加)数据,是SQL中常用的数据操作语句之一。它可以用多种方式使用,包括插入完整的行、插入行的一部分、插入多行以及插入某些查询的...

当 SQL Server(mssql-jdbc) 遇上 BigDecimal → 精度丢失,真坑!

开心一刻  中午和哥们一起喝茶  哥们说道:晚上喝酒去啊...

MYSQL有哪些数据类型(mysql有哪些数据类型,有哪些运算符)

整理下以便查阅,还想吐槽下:这头条怎么就不能给文章分类呢?整数类型...

使用MySQL分区的注意事项(使用mysql分区的注意事项有哪些)

MySQL分区是将一个表分解成多个区块进行操作和保存,从而降低每次操作的数据量,提高性能。从逻辑上看,只有一个表,但物理上这个表可能由多个物理分区组成,每个分区都是一个独立的对象,可以进行独立处理。...

取消回复欢迎 发表评论: