# 写一个判断是小数的函数
def is_float(s):
    s = str(s)
    if s.count('.') == 1:
        s_left = s.split('.')[0]
        s_right = s.split('.')[1]
        if s_left.isdigit() and s_right.isdigit():
            return True
        elif s_left.startswith('-')and s_left.count('-') == 1 and s_right.isdigit():
            if s_left.split('-')[1].isdigit():
                return True
    return False
# 下面的代码和以上相同,是加了注释的 ^_^
def is_float(s):
    s = str(s)   # 强制转化操作是因为传进来的被判断对象的类型具有不确定性,你需要将其统一在一个起点进行处理。
    if s.count('.') == 1:  # 小数的首要前提就是有且只有一个小数点。
        s_left = s.split('.')[0]  # 以小数点为分界点把字符串拆成左右两部分以备进一步分析。
        s_right = s.split('.')[1]
        if s_left.isdigit() and s_right.isdigit(): # 小数点左右都是纯的正整数,一个标准的正小数情况。
            return True
        elif s_left.startswith('-')and s_left.count('-') == 1 and s_right.isdigit():
            # 负小数情况稍复杂,首先以负号开头,排除多个负号情况,同时小数点右侧是纯的正整数,在此情况下,
            if s_left.split('-')[1].isdigit():  # 小数点左侧负号身后的部分如果是正整数字符,是个合法的负小数
                return True
    return False
    # 除了以上正小数和负小数两种合法的情况外,其它均是不合法情况,上边的判断路线也走不进去,直接返回False结束。
    # 而当符合上面的任何条件都会判断是合法小数,返回True结束程序,也走不到最后的return False这个语句。
    # 所以不用看到程序最后一句是 return False 而担心。
# 以下是检测上面函数的用例,有没包含的情况吗?
print(is_float(123.456))
print(is_float(-123.456))
print(is_float(123))
print(is_float(-123))
print(is_float('123.45.6'))
print(is_float('123.4a'))
print(is_float('123a.456'))
print(is_float('-1-23.456'))
print(is_float(.456))
print(.456)  # 0.456
print(is_float(-.456))
print(-.456)  # -0.456
print(is_float('..456'))
print(is_float(--123))
print(--123)  # 123 是整数
print(is_float(--.456))
print(--.456)   # 0.456 是小数
print(is_float(''))