我正在Django / Python中建立一个约会网站。我有生日日期,需要根据他们的生日来显示这个人的十二生肖。
之前有人这样做过吗?实现这一目标的最有效方法是什么?
答案 0 :(得分:15)
我以前做过这个。我最终得到的最简单的解决方案是以下键/值的数组:
120:Cap, 218:Aqu, 320:Pis, 420:Ari, 521:Tau,
621:Gem, 722:Can, 823:Leo, 923:Vir, 1023:Lib
1122:Sco, 1222:Sag, 1231: Cap
然后以mdd
格式写出生日期,即月份编号(从1开始为1月)和两位数日期编号(01-31)。遍历数组,如果日期小于或等于数组中的项目,则表示您有星号。
修改强> 我需要这个,所以这里的概念是一个工作函数
zodiacs = [(120, 'Cap'), (218, 'Aqu'), (320, 'Pis'), (420, 'Ari'), (521, 'Tau'),
(621, 'Gem'), (722, 'Can'), (823, 'Leo'), (923, 'Vir'), (1023, 'Lib'),
(1122, 'Sco'), (1222, 'Sag'), (1231, 'Cap')]
def get_zodiac_of_date(date):
date_number = int("".join((str(date.date().month), '%02d' % date.date().day)))
for z in zodiacs:
if date_number <= z[0]:
return z[1]
答案 1 :(得分:8)
您可以向他们提供有关position of the planets和星星的更多信息。
import ephem
>>> u = ephem.Uranus()
>>> u.compute('1871/3/13')
>>> print u.ra, u.dec, u.mag
7:38:06.27 22:04:47.4 5.46
>>> print ephem.constellation(u)
('Gem', 'Gemini')
答案 2 :(得分:8)
在找到匹配项之前,使用bisect比迭代更有效,但是一年中每一天的查找表仍然更快,而且实际上并不那么大。
from bisect import bisect
signs = [(1,20,"Cap"), (2,18,"Aqu"), (3,20,"Pis"), (4,20,"Ari"),
(5,21,"Tau"), (6,21,"Gem"), (7,22,"Can"), (8,23,"Leo"),
(9,23,"Vir"), (10,23,"Lib"), (11,22,"Sco"), (12,22,"Sag"),
(12,31,"Cap")]
def zodiac_sign(m,d):
return signs[bisect(signs,(m,d))][2]
assert zodiac_sign(3,9) == "Pis"
assert zodiac_sign(6,30) == "Can"
答案 3 :(得分:2)
var ZZ=[1231,1222,1122,1023,923,823,722,621,521,420,321,220,121];
var ZN=['Capricorn','Sagittarius','Scorpio','Libra','Virgo','Leo','Cancer', 'Gemini','Taurus','Aries','Pisces','Aquarius','Capricorn'];
var d8=new Date();
var m=d8.getMonth()+1;
var d=d8.getDate();
//m=1;d=1
var mdd=parseInt(''+m+(d<9?'0'+d:d));
var i=0;while(ZZ[i]>mdd && i<ZZ.length){i++}--i;
var RV='Born '+m+'/'+d+' - Star Sign: '+ZN[i];RV
答案 4 :(得分:0)
def zodiac(day,month):
signs=[('Capricorn',19),('Aquarius',18),('Pisces',20),('Aries',19),('Taurus',20),('Gemini',20) ,('Cancer',22),('Leo',22) ,('Virgo',22) ,('Libra',22) ,('Scorpio',21),('Sagittarius',21),('Capricorn',)]
if(day<=signs[month-1][1]):
return signs[month-1][0]
else:
return signs[month][0]