zoukankan      html  css  js  c++  java
  • 输入( 年 ,月 )打印日历()

    def is_leapyear( year ):
        return True if year % 4 ==  0 and year % 100 !=  0 or year % 400 == 0 else False


    def days_year( year ):
       return 366 if is_leapyear( year ) else 365


    def days_month( year , month ):
        l = [ 31 , 29 , 31 , 30 , 31 , 30 , 31 , 31 , 30 , 31 , 30 , 31 ]
        u = [ 31 , 28 , 31 , 30 , 31 , 30 , 31 , 31 , 30 , 31 , 30 , 31 ]
        return l[ month-1 ]if is_leapyear( year ) else u[ month-1 ]


    def get_week( year , month ):
        days = 0
        if ( 1990 <= year <= 2018 ) or ( 1 <= month <= 12 ) :
            for y in range( 1990 , year ):
                days += days_year( y )
            for m in range( 1 , month ):
                days += days_month( year , m )
            return ( days + 1 ) % 7
    def get_week( year , month ): days = 0 if ( 1990 <= year <= 2018 ) or ( 1 <= month <= 12 ) : for y in range( 1990 , year ): days += days_year( y ) for m in range( 1 , month ): days += days_month( year , m ) return ( days + 1 ) % 7
    while True: year , month = eval( input( ' Input year and month (year , month): ' ) ) days = 0 if ( 1990 <= year <= 2018 ) or ( 1 <= month <= 12 ): print( ' {}年{}月'.format(year,month) ) print( ' 日 一 二 三 四 五 六' ) for week in range( get_week( year , month ) ): print( ' '+' ',end='' ) for day in range( 1 , days_month( year , month ) + 1 ): print( ' {: <2}'.format( day ) , end='' ) if ( day + get_week( year , month ) ) % 7 == 0 or day == days_month( year , month ) : print('') else : continue
  • 相关阅读:
    【JVM性能调优】检测最耗cpu的线程的脚本
    JUC之ThreadPoolExecutor实现原理
    HashMap实现原理
    JUC之阻塞队列BlockingQueue的实现原理
    dubbo实践
    .net 技术基础
    日志等级
    CentOS 笔记(六) 历史命令 自动补充
    CentOS 笔记(五) 常用工具
    CentOS 笔记(二) 端口占用,进程查看
  • 原文地址:https://www.cnblogs.com/TyroneYang/p/10075678.html
Copyright © 2011-2022 走看看