博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Linux shell实现阳历转农历
阅读量:4116 次
发布时间:2019-05-25

本文共 2960 字,大约阅读时间需要 9 分钟。

闲来无事,想在Linux下用shell写一个阳历转农历的脚本,断断续续大概一个星期终于搞定。现在拿出来与大家分享。

功能:将具体的阳历日期转换为农历日期。
参数格式(无参数默认为当前系统日期):yyyymmdd
如2013年1月1日:
$./lunar.sh 20130101

4709-11-20

完整数据下载地址:

主要脚本lunar.sh代码如下

#!/bin/sh
 
DATE=$@
[ "$DATE" = "" ] && DATE=$(date +%Y%m%d)
 
date_year=$(echo $DATE |sed 's/^\(.\{4\}\).*/\1/')
date_month=$(echo $DATE |sed 's/.*\(..\)..$/\1/')
date_day=$(echo $DATE |sed 's/.*\(..\)$/\1/')
date_days=$(date -d $DATE +%j)
 
lunar_year=$(sed /$date_year/!d databases |sed 's/^\(....\).*/\1/')
 
lunar_year_data=$(sed /$date_year/!d databases |sed 's/.*\ \(.*\)/\1/')
lunar_year_data_bin=$(echo "ibase=16;obase=2;$lunar_year_data"|bc |sed -e :a -e 's/^.\{1,23\}$/0&/;ta')
 
new_year_month_bin=$(echo $lunar_year_data_bin |sed -e 's/^.\{17\}\(.\{2\}\).*/\1/')
new_year_month=$(echo "ibase=2;$new_year_month_bin"|bc |sed -e :a -e 's/^.\{1,1\}$/0&/;ta')
 
new_year_day_bin=$(echo $lunar_year_data_bin |sed -e 's/.*\(.\{5\}\)$/\1/')
new_year_day=$(echo "ibase=2;$new_year_day_bin"|bc |sed -e :a -e 's/^.\{1,1\}$/0&/;ta')
 
new_year_days=$(date -d $date_year$new_year_month$new_year_day +%j)
 
lunar_days=$(expr $date_days - $new_year_days + 1)
 
befor_or_after=0
 
if [ "$lunar_days" -le "0" ]; then
   befor_or_after=1
   date_year=$(($date_year-1))
 
   lunar_year=$(sed /$date_year/!d databases |sed 's/^\(....\).*/\1/')
 
   lunar_year_data=$(sed /$date_year/!d databases |sed 's/.*\ \(.*\)/\1/')
   lunar_year_data_bin=$(echo "ibase=16;obase=2;$lunar_year_data"|bc |sed -e :a -e 's/^.\{1,23\}$/0&/;ta')
fi
 
lunar_leap_month_bin=$(echo $lunar_year_data_bin |sed -e 's/^\(.\{4\}\).*/\1/')
lunar_leap_month=$(echo "ibase=2;$lunar_leap_month_bin"|bc)
 
lunar_month_all_bin=$(echo $lunar_year_data_bin |sed -e 's/^.\{4\}\(.\{13\}\).*/\1/')
[ "$lunar_leap_month" = "0" ] && lunar_month_all_bin=$(echo $lunar_year_data_bin |sed -e 's/^.\{4\}\(.\{12\}\).*/\1/')
lunar_month_all=$(echo $lunar_month_all_bin |sed -e 's/0/29\ /g' |sed -e 's/1/30\ /g')
 
if [ "$befor_or_after" = "0" ];then
   lunar_month=1
   lunar_day=$lunar_days
   for i in $lunar_month_all
   do
      if [ "$lunar_day" -gt "$i" ]; then
         lunar_day=$(($lunar_day - $i))
         lunar_month=$(($lunar_month + 1))
      fi
   done
else
   lunar_month=12
   lunar_day=$((-$lunar_days))
   lunar_month_all_bin=$(echo $lunar_month_all_bin |rev)
   lunar_month_all=$(echo $lunar_month_all_bin |sed -e 's/0/29\ /g' |sed -e 's/1/30\ /g')
   for i in $lunar_month_all
   do
      if [ "$lunar_day" -gt "$i" ]; then
         lunar_day=$(($lunar_day - $i))
         lunar_month=$(($lunar_month - 1))
      else
         lunar_day=$(($i - $lunar_day))
         break
      fi
   done
fi
 
if [ "$lunar_leap_month" = "0" ]; then
    echo $lunar_year-$lunar_month-$lunar_day
else
   if [ "$lunar_leap_month" -ge "$lunar_month" ]; then
      echo $lunar_year-$lunar_month-$lunar_day
   elif [ "$befor_or_after" = "0" ]; then
      if [ "$(($lunar_leap_month + 1))" = "$lunar_month" ];then
         lunar_month=$(($lunar_month - 1))
         echo $lunar_year-*$lunar_month-$lunar_day
      else
         lunar_month=$(($lunar_month - 1))
         echo $lunar_year-$lunar_month-$lunar_day
      fi
   else
      echo $lunar_year-$lunar_month-$lunar_day
   fi
fi

转载地址:http://wlypi.baihongyu.com/

你可能感兴趣的文章
Valid Palindrome 简单的回文判断
查看>>
Pascal's Triangle -- 生成杨辉三角
查看>>
Pascal's Triangle II 生成杨辉三角中的某行
查看>>
Minimum Depth of Binary Tree -- 二叉树的最小深度 DFS 加剪枝
查看>>
Climbing Stairs 爬楼梯方法 动态规划
查看>>
Merge Two Sorted Lists 合并两个有序链表
查看>>
pow(x,n) 为什么错这么多次
查看>>
Jump Game 动态规划
查看>>
Binary Tree Maximum Path Sum 自底向上求解(重重重重)
查看>>
Subsets 深搜
查看>>
Subsets II
查看>>
Edit Distance 字符串距离(重重)
查看>>
Gray Code 格雷码
查看>>
对话周鸿袆:从程序员创业谈起
查看>>
web.py 0.3 新手指南 - 如何用Gmail发送邮件
查看>>
web.py 0.3 新手指南 - RESTful doctesting using app.request
查看>>
web.py 0.3 新手指南 - 使用db.query进行高级数据库查询
查看>>
web.py 0.3 新手指南 - 多数据库使用
查看>>
一步步开发 Spring MVC 应用
查看>>
python: extend (扩展) 与 append (追加) 的差别
查看>>