跳到内容
🛠️ToolsShed

Julian Date Converter

在公历日期和儒略日数之间转换。

关于儒略日数

儒略日数(JDN)是从公元前4713年1月1日起的连续日数计数。它消除了不同历法系统的混乱,在天文学中广泛用于精确的日期和时间计算。

关于此工具

儒略日数(JDN)是从公元前4713年1月1日开始的连续日数计算,广泛应用于天文学、卫星计算和历史年代测定。与熟悉的公历不同,公历以月份和年份循环,而儒略日数为任何给定日期提供单一、明确的数字——这使得跨越数个世纪进行精密的天文观测和计算时,无需担心历法改革或地区日期惯例的混淆。

使用此转换器时,只需输入公历日期(月、日和年)以获得相应的儒略日数,或输入儒略日数以将其转换回标准日历日期。该工具使用已确立的天文公式进行即时计算,对于处理历史记录、天文数据或需要通用日期参考系统的软件的任何人都很有用。

常见问题

代码实现

def gregorian_to_jdn(year: int, month: int, day: int) -> float:
    """Convert Gregorian date to Julian Day Number (Meeus algorithm)."""
    if month <= 2:
        year -= 1
        month += 12
    A = year // 100
    B = 2 - A + A // 4
    return int(365.25 * (year + 4716)) + int(30.6001 * (month + 1)) + day + B - 1524.5

def jdn_to_gregorian(jdn: float) -> tuple[int, int, int]:
    """Convert Julian Day Number to Gregorian date (Meeus algorithm)."""
    jdn = jdn + 0.5
    Z = int(jdn)
    if Z < 2299161:
        A = Z
    else:
        alpha = int((Z - 1867216.25) / 36524.25)
        A = Z + 1 + alpha - alpha // 4
    B = A + 1524
    C = int((B - 122.1) / 365.25)
    D = int(365.25 * C)
    E = int((B - D) / 30.6001)
    day = B - D - int(30.6001 * E)
    month = E - 1 if E < 14 else E - 13
    year = C - 4716 if month > 2 else C - 4715
    return year, month, day

jdn = gregorian_to_jdn(2024, 3, 15)
print(f"2024-03-15 → JDN: {jdn}")
y, m, d = jdn_to_gregorian(jdn)
print(f"JDN {jdn} → {y}-{m:02d}-{d:02d}")

Comments & Feedback

Comments are powered by Giscus. Sign in with GitHub to leave a comment.