using System;
using System.Collections.Generic;
public class Program
    {
    /********************主函数************************/
       public static void Main()
          {
              /******************获取用户输入的年月**************/
              while(true)
                  {
                      int year1,month1;
                      while(true)
                         {
                            Console.Write("请输入年份(1900-2100):");
                            year1=int.Parse(Console.ReadLine());
                            if(year1<1900||year1>2100)
                               {
                                  Console.Write("年份输入错误,按回车键后重新输入");
                                  Console.ReadLine();
                                  Console.Clear();
                               }
                            else
                                {
                                   Console.Write("请输入月份(1-12):");
                                   month1=int.Parse(Console.ReadLine());
                                   if(month1<1||month1>12)
                                      {
                                         Console.Write("月份输入错误,按回车键后重新输入");
                                         Console.ReadLine();
                                         Console.Clear();
                                      }
                                   else
                                      {
                                         break;
                                      }
                                  }
                              }

/*********************************************************/
/********************获取月份数据,包括前面的空格*********/
                List<string> dats=new List<string>();//定义一个集合,用来存放月份里面的天数和要打印的空白数
                Console.WriteLine(GetCrossDaysFrom1900(year1,month1));//输出从1900年1月1号到输入年份的天数
                int dayofWeek=GetCrossDaysFrom1900(year1,month1)%7+1;
                int space=dayofWeek-1;
                for(int a=1;a<=space;a++)
                    {
                       dats.Add(" ");
                    }
                for(int b=1;b<=GetDaysOfMonth(year1,month1);b++)
                   {
                      dats.Add(b.ToString());
                   }
/*********************************************************/
/********************输出某年某月的日历*******************/
              Console.WriteLine("***********************************************");
              Console.Write("一\t二\t三\t四\t五\t六\t日");
              for(int d=0;d<dats.Count;d++)
                 {
                     if(d%7==0)//没打印7个数据就换行
                         {
                            Console.WriteLine();
                         }
                     Console.Write(dats[d]+"\t");
                 }
              Console.WriteLine();
              Console.WriteLine("*************************************************");
              Console.Write("按回车键继续");
              Console.ReadLine();
              Console.Clear();
            }
         }
/********************从1900年1月1号到输入年份的天数*********/
        static int GetCrossDaysFrom1900(int year2, int month2)
            {
                int days=0;
                for(int i=1900;i<year2;i++)//计算从1900年一月一号到输入的这年一月一号一共有多少天
                    {
                       if(i%4==0&&i%100!=0||i%400==0)
                          {
                             days+=366;
                           }
                       else
                           {
                              days+=365;
                           }
                     }
                 for(int j=1;j<month2;j++)
                    {
                        if(j==2)  //判断二月有多少天
                          {
                              if(year2%4==0&&year2%100!=0||year2%400==0)//判断是不是瑞年
                                 {
                                     days+=29;
                                 }
                              else
                                 {
                                     days+=28;
                                  }
                            }
                        else if(j<=7&&j%2!=0||j>7&&j%2==0)//计算大月有多少天
                           {
                               days+=31;
                            }
                        else
                            {
                               days+=30;
                             }
                       }
                    return days;
                 }
    /****************哪年哪月有多少天*******************/
          static int GetDaysOfMonth(int year3, int month3)
              {
                 int dates;
                 if(month3==2)
                    {
                       if(year3%4==0&&year3%100!=0||year3%400==0)
                          {
                             dates=29;
                          }
                       else
                          {
                             dates=28;
                           }

}
                  else if(month3<=7&&month3%2!=0||month3>7&&month3%2==0)
                      {
                         dates=31;
                      }
                  else
                      {
                         dates=30;
                      }
                   return dates;
               }
         }

C#:查询某年(1900-2100)某月的日历的更多相关文章

  1. 关于SQL查询某年数据 和DATEPART 函数的使用

    数据库查询某年数据(sql server)select *from 表名 where YEAR(存时间的字段名) =某年select *from News where YEAR(addDate) =2 ...

  2. 用sql查询当天,一周,一个月的数据

    用sql查询当天,一周,一个月的数据   数据查询,不管在网站还是在系统,都很常见,下文是介绍最常见的以日期查询的语句 select * from ShopOrder where datediff(w ...

  3. RobotFramework:查询条件为最近一个月的数据(2019-07-09 00:00:00.000 到 2019-08-07 23:59:59.999)

    自动化测试中遇到,默认查询条件为最近一个月,所以起始时间就应该为(2019-07-09 00:00:00.000 到  2019-08-07 23:59:59.999) test ${current_ ...

  4. Mysql 查询天、周,月,季度、年的数据

    Mysql 查询天.周,月,季度.年的数据 今天 select * from 表名 where to_days(时间字段名) = to_days(now()); 昨天 SELECT * FROM 表名 ...

  5. sql server查询某年某月有多少天

    sql语句如下: ),) date from (),,)+'-01' day) t1, ( ) t2 ),) ),,)+'%' 查询结果如下: 2017年2月共有28天,查询出28条记录.

  6. 报表统计——java实现查询某年某月每天数据,没数据补0

    一般图表绘制例如echarts等,返回数据格式都大同小异.重点是利用sql或者java实现数据格式的转型,接下来是关键部分: 1.前提:提供的工具方法——获取某月有多少天 //通过年份和月份确定该月的 ...

  7. 报表统计——java实现查询某年12个月数据,没数据补0

    一般图表绘制例如echarts等,返回数据格式都大同小异.重点是利用sql或者java实现数据格式的转型,接下来是关键部分: 1.mapper层sql语句,返回统计好的月份与对应月份的数据. < ...

  8. sql查询当天,一周,一个月数据的语句

    --查询当天:  select * from info where DateDiff(dd,datetime,getdate())=0 --查询24小时内的: select * from info w ...

  9. 需求:输入一个年份和月份 ,显示当前月日情况 ,星期数要对应准确 * 1.1900年1月1号开始 * 2.星期 : 直接用总天数对7求余数 31 28 59 / 7 = 5 * 3.以\t来个开

    public class Demo4 { /** * @param args */ public static void main(String[] args) { // TODO Auto-gene ...

随机推荐

  1. 超炫的时间轴jquery插件Timeline Portfolio

    Timeline Portfolio是一款按时间顺序专业显示事件的jquery时间轴插件,可以根据时间的先后嵌入各种媒体包括微博,视频和地图等.这个展现的模式非常适合设计师的作品集和个人简历的展示.T ...

  2. thinkphp 配置项总结

    'URL_PATHINFO_DEPR'=>'-',//修改URL的分隔符 'TMPL_L_DELIM'=>'<{', //修改左定界符 'TMPL_R_DELIM'=>'}&g ...

  3. C#综合揭秘——细说进程、应用程序域与上下文之间的关系

    引言 本文主要是介绍进程(Process).应用程序域(AppDomain)..NET上下文(Context)的概念与操作.虽然在一般的开发当中这三者并不常用,但熟悉三者的关系,深入了解其作用,对提高 ...

  4. Oracle中 Instr 这个函数

    http://www.jb51.net/article/42369.htm sql :charindex('字符串',字段)>0 charindex('administrator',MUserI ...

  5. js记录重复字母的个数

    var str = "hello"; var obj = {}; for (var i = 0; i < str.length; i++) { var v = str.cha ...

  6. iOS 环信消息撤回

    这两天在做环信的消息回撤,在网上找了许久没有这种案例,之后官方的一些方法,但是自己做,还是需要花点时间去整理,所以我决定等我把这个做好之后,分享给大家,如果做的不好多多指教,谢谢- 首先要实现消息撤回 ...

  7. 通过浏览器navigator判断浏览器版本或者手机类型&&判断微信访问

    javascript 的navigator属性,不常用,但是用处也不少,主要用处是在做浏览器兼容的问题的时候,现在有的网站已经不兼容IE6,用户假如用IE6浏览网页的话,会提示浏览器升级等信息.或者判 ...

  8. UTF编码检测

    最近工作上正好需要进行UTF编码检测,自己写了一个,分享给大家,希望可以帮得上有需要用的朋友 public bool isUtf8(byte[] rawText) { bool result = tr ...

  9. [转载]【虚拟化系列】VMware vSphere 5.1 虚拟机管理

    转载自:http://mabofeng.blog.51cto.com/2661587/1019497 在上一博文中我们安装了强大的VMware vCenter管理中心,通过VMware vSphere ...

  10. Codeforces 712B

    B. Memory and Trident time limit per test:2 seconds memory limit per test:256 megabytes input:standa ...