Simple Calculator(算法初阶,代码基础,“纯”手撕)

news2024/9/24 2:30:31

简单计算器:仅适用无括号加减乘除,算法初阶,代码基础,不调库或模块“纯”手撕。


(笔记模板由python脚本于2024年09月22日 12:08:02创建,本篇笔记适合喜欢用python解决实际问题的coder翻阅)


【学习的细节是欢悦的历程】

  • Python 官网:https://www.python.org/

  • Free:大咖免费“圣经”教程《 python 完全自学教程》,不仅仅是基础那么简单……
    地址:https://lqpybook.readthedocs.io/


  自学并不是什么神秘的东西,一个人一辈子自学的时间总是比在学校学习的时间长,没有老师的时候总是比有老师的时候多。
            —— 华罗庚


  • My CSDN主页、My HOT博、My Python 学习个人备忘录
  • 好文力荐、 老齐教室
等风来,不如追风去……


仅适用没有括号的加减乘除
Simple Calculator
(算法初阶代码基础不调库或模块“纯”手撕)


本文质量分:

95 95 95

本文地址: https://blog.csdn.net/m0_57158496/article/details/142466709

CSDN质量分查询入口:http://www.csdn.net/qc


目 录

  • ◆ Simple Calculator
    • 1、程序说明
    • 2、运行效果
    • 3、代码解读
    • 4、calculate的另一种写法
    • 5、完整源码(Python)


◆ Simple Calculator


1、程序说明


一、概述

  这是一个简单的计算器程序,它可以处理没有括号的算式,包括加法、减法、乘法和除法。程序仅支持0和自然数的四则混合运算。用户可以通过输入算式来执行计算,并且可以多次输入算式进行计算。若输入的算式不符合要求,程序会给出相应的错误提示。


二、功能说明

  • 输入验证:确保用户输入的算式只包含数字、四则运算符和小数点,且格式正确。
  • 算式解析:将算式转换为可以处理的列表形式。
  • 算式计算:支持不带括号的四则混合运算,先执行乘除运算,然后执行加减运算。
  • 结果输出:将计算结果输出给用户。
  • 优雅退出:用户输入“00”即可退出程序。

  程序的优点在于它的简单性和易用性,用户可以轻松地输入算式并得到结果。


三、使用方法

  • 运行程序。
  • 根据提示输入算式,例如:3+5*2-4/2
  • 按下回车键进行计算。
  • 查看计算结果,并根据提示继续使用或退出。

四、注意事项

  • 输入的算式不能为空。
  • 算式中只能包含数字、加号(+)、减号(-)、乘号(*)、除号(/)和小数点(.)。
  • 算式末尾必须是数字。
  • 不允许连续的运算符。
  • 算式不可以有连续的符号,如“++”、“-/”、“+*”、“//”等。
  • 每个数值中只能包含一个小数点。

五、错误处理

  • 若输入的算式不符合要求,程序将抛出ValueError错误提示。
  • 用户可根据错误提示修改算式,然后重新输入。

六、程序优势

  • 无需安装第三方库,纯Python实现。
  • 代码结构清晰,易于理解和维护。
  • 具有较好的错误处理机制,提高用户体验。



回页目录


2、运行效果


  • 界面
    在这里插入图片描述

  • 计算
    在这里插入图片描述
    在这里插入图片描述

  • 错误输入
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  • 退出
    在这里插入图片描述



回页目录


3、代码解读


一、文件头部

#!/usr/bin/env python3
# coding: utf-8

  1. #!/sur/bin/nve:指定解释器的路径,此处应为#!/usr/bin/env python3,表示使用Python 3解释器。
  2. # coding: utf-8:指定源文件编码为UTF-8,以支持中文等非ASCII字符。

二、程序结构

  1. validate_input(s:str) -> bool:输入验证函数,用于检查用户输入的算式是否合法。
  2. calculate(s:str) -> float:计算函数,用于解析并计算用户输入的算式。
  3. calculator(s:str) -> float:计算器主函数,调用validate_inputcalculate函数,返回计算结果。
  4. main() -> None:程序主入口,提供用户交互界面,循环接收用户输入并进行计算。

三、函数说明

  • split_expression

def split_expression(s:str) -> list:
    ''' 拆分算式 '''
    return s.replace('+', ' + ').replace('-', ' - ').replace('*', ' * ').replace('/', ' / ').split()


  1. validate_input(s:str) -> bool.

def validate_input(s:str) -> bool:
    ''' 输入验证 '''

    # expression空验证
    if not s:
        raise ValueError(f"\n{f' 算式不可为空 ':-^36}\n")    

    # 字符有效验证
    chars = tuple('0123456789+-/*.')
    for char in s:
        if char not in chars:
            raise ValueError(f"\n{f' 错误字符:{char} ':-^35}\n") 

    s = split_expression(s) # 拆分算式成列表

    # expression末尾验证
    if not s[-1][-1].isdigit():
        raise ValueError(f"\n{f' 算式末尾不可以是:{s[-1]} ':-^31}\n")    

    # 数值小数点、连续运算符、零除验证
    if s[0].count('.') > 1:
        raise ValueError(f"\n{f' “{s[0]}”小数点错误 ':-^37}\n") 
    for i in range(1, len(s)):
        if not s[i-1].replace('.', '').isdigit() and not s[i].replace('.', '').isdigit():
            raise ValueError(f"\n{f' 算式不可以有连续符号:{s[i-1]}{s[i]} ':-^30}\n") 
        elif s[i].count('.') > 1:
            raise ValueError(f"\n{f' “{s[i]}”小数点错误 ':-^37}\n") 
        elif s[i]=='/' and set(s[i+1].replace('.', ''))=={'0'}:
            raise ValueError(f"\n{f' 零除错误 ':-^36}\n") 
    
    return True

  • 验证用户输入的算式是否合法。
  • 验证输入的算式是否为空。
  • 验证算式中的字符是否有效。
  • 将算式转换为列表,方便后续处理。
  • 验证算式末尾是否为数字。
  • 验证每个数值的小数点数量和连续符号。
  • 验证零除错误。

  1. calculate(s:str) -> float

def calculate(s:str) -> float:
    ''' 算式解析并计算 '''
    numbers = [] # 数值
    signs = [] # 运算符
    local_num = '' # 当前数值

    # 拆分算式
    for char in s:
        if char.isdigit() or char=='.':
            local_num += char
        else:
            numbers.append(float(local_num))
            signs.append(char)
            local_num = ''

    numbers.append(float(local_num)) # 追加最后一个数值

    # 计算乘除
    newnumbers = numbers[:1]
    for i in range(1, len(numbers)):
        if signs[i-1] == '*':
            newnumbers[-1] = newnumbers[-1] * numbers[i]
            signs[i-1] = ''
        elif signs[i-1] == '/':
            newnumbers[-1] = newnumbers[-1] /numbers[i]
            signs[i-1] = ''
        else:
            newnumbers.append(numbers[i])
    signs = [sign for sign in signs if sign] # 更新运算符列表

    # 处理+、-符号:列表解析,用前插空字符对齐运算符与数值列表,遍历zip拼接“运算符-数值”对,更新到newnumbers
    newnumbers = [float(f"{number[0]}{number[1]}") for number in zip(['']+signs, newnumbers)]
    return sum(newnumbers) # 求和(加)并返回

  • 首先将算式拆分为数字和运算符两个列表。
  • 然后优先计算乘法和除法。
  • 然后处理加法和减法,将减法转换为加法(例如,5 - 3转换为5 + (-3))。
  • 最后对处理后的数字列表求和,得到最终结果。

  1. calculator(s:str) -> float

def calculator(s:str) -> float:
    ''' 计算器 '''
    result = calculate(s) # 调用计算解析函数
    return int(result) if round(result) == result else result # 结果是整,去尾0

  • 调用validate_input进行输入验证。
  • 调用calculate进行算式计算。
  • 返回计算结果,若结果为整数则转换为整数类型。

  1. main() -> None

def main() -> None:
    ''' 主程序 '''
    while True:
        clear = '\033[2J' # 清屏字符串(windows系统低版本不支持)
        print(f"\n{clear}")        
        text = input(f"\n{' 简单计算器 ':=^37}\n{'(不带括号的四则运算,输入00退出)':^26}\n\n\n{' 回车确认执行计算 ':-^34}\n\n{'输入算式:':>7}").strip()

        if text == '00':
            print(f"{clear}\n{' 您已退出“简单计算器”!':^33}\n\n{f' 谢谢您使用“简单计算器”。':-^31}\n")
            break # break更优雅

        validate_input(text) # 输入验证
        result = calculator(text) # 计算表达式
        input(f"\n\n{'结果:':>9}{result}\n\n\n{'':=^42}\n{'(任意键继续……)':^35}") 

  • 提供用户交互界面,允许用户输入算式。
  • 调用 validate_input 函数验证输入。
  • 调用 calculator 函数计算算式。
  • 输出计算结果。
  • 循环接收用户输入,直到用户输入“00”退出。

四、程序入口

  • 入口
if __name__ == '__main__':
    try:
        main()  # 启动主程序
    except ValueError as e:
        print(e)  # 打印错误信息

  1. 程序入口为if __name__ == '__main__':块,确保当模块被直接运行时,main()函数会被调用。
  2. 使用try...except语句块捕获并处理ValueError异常,提高程序的健壮性。

  这个程序的逻辑清晰,代码简洁,易于理解和维护。通过这个简单的计算器,用户可以快速进行基本的数学运算。



回页目录


4、calculate的另一种写法



def calculate(s:str) -> float:
    ''' 算式解析并计算 '''
    s = [float(part) if part.replace('.', '').isdigit() else part for part in split_expression(s)] # 三元操作语句列表解析数值

    # 算乘除
    k = 1
    while k < len(s)-1:
        if s[k] == '*':
            s[k-1] = s[k-1]*s.pop(k+1) # 用积重写乘号前数值
            s.pop(k) # 删除乘号
        elif s[k] == '/':
            s[k-1] = s[k-1]/s.pop(k+1) # 用商重写乘号前数值
            s.pop(k) # 删除乘号
        else:
            k += 1 # 跳过加减运算符和数值

    # 算加减
    k = 1
    while k < len(s)-1:
        if s[k] == '+':
            s[k-1] = s[k-1] + s.pop(k+1) # 用和重写加号前数值
            s.pop(k) # 删除加号
        elif s[k] == '-':
            s[k-1] = s[k-1]- s.pop(k+1) # 用和重写加号前数值
            s.pop(k) # 删除减号
        else:
            k += 1 # 跳过数值

    return s[0] # 返回计算结果


ai点评:


  两个calculate函数的实现都有其独特之处,下面是对它们的重新评估:


第一个calculate函数:

优点:

  1. 逻辑清晰:首先处理乘除,然后处理加减,符合数学运算的优先级规则。
  2. 易于理解:通过两个步骤分别处理不同的运算符,使得代码结构更加清晰。
  3. 错误处理:在处理乘除时,如果遇到乘号或除号,会正确地更新列表中的数值,并移除运算符。

缺点:

  1. 效率:需要两次遍历列表,一次处理乘除,一次处理加减。
  2. 代码量:相对较长,因为分步骤处理。

第二个calculate函数:

优点:

  1. 代码简洁:使用单次遍历和列表解析,代码量更少。
  2. 效率:在一次遍历中完成乘除运算,减少了遍历次数。
  3. 直接操作:直接在原列表上操作,减少了额外的数据结构使用。

缺点:

  1. 可读性:由于代码较为紧凑,可能不如第一个实现容易理解。
  2. 错误处理:在处理运算符时,如果列表操作不当,可能会导致索引错误。

总结:

  • 如果你的目标是编写一个易于理解和维护的代码,第一个calculate函数可能更适合。
  • 如果你追求代码的简洁性和效率,第二个calculate函数可能更符合你的需求。

  两个实现都是有效的,并且都可以作为学习笔记中的示例。选择哪一个取决于你的个人偏好和你对代码质量的要求。如果你想要一个更加平衡的方案,可以考虑结合两个实现的优点,创建一个既高效又易于理解的版本。

  我个人倾向于第二个实现,因为它更加简洁,并且在现代编程中,效率往往是一个重要的考虑因素。不过,确保你的代码有充分的注释,以提高可读性。


回页目录


5、完整源码(Python)

(源码较长,点此跳过源码)


涅槃版

#!/sur/bin/nve python3
# coding: utf-8


'''

简单计算器:处理没有括号的+-*/算式,可以实现四则混合运算仅支持0和自然数。

程序不调用库和模块,纯代码手撕。


'''


def split_expression(s:str) -> list:
    ''' 拆分算式 '''
    return s.replace('+', ' + ').replace('-', ' - ').replace('*', ' * ').replace('/', ' / ').split()


def validate_input(s:str) -> bool:
    ''' 输入验证 '''

    # expression空验证
    if not s:
        raise ValueError(f"\n{f' 算式不可为空 ':-^36}\n")    

    # 字符有效验证
    chars = tuple('0123456789+-/*.')
    for char in s:
        if char not in chars:
            raise ValueError(f"\n{f' 错误字符:{char} ':-^35}\n") 

    s = split_expression(s) # 拆分算式成列表

    # expression末尾验证
    if not s[-1][-1].isdigit():
        raise ValueError(f"\n{f' 算式末尾不可以是:{s[-1]} ':-^31}\n")    

    # 数值小数点、连续运算符、零除验证
    if s[0].count('.') > 1:
        raise ValueError(f"\n{f' “{s[0]}”小数点错误 ':-^37}\n") 
    for i in range(1, len(s)):
        if not s[i-1].replace('.', '').isdigit() and not s[i].replace('.', '').isdigit():
            raise ValueError(f"\n{f' 算式不可以有连续符号:{s[i-1]}{s[i]} ':-^30}\n") 
        elif s[i].count('.') > 1:
            raise ValueError(f"\n{f' “{s[i]}”小数点错误 ':-^37}\n") 
        elif s[i]=='/' and set(s[i+1].replace('.', ''))=={'0'}:
            raise ValueError(f"\n{f' 零除错误 ':-^36}\n") 
    
    return True


def calculate(s:str) -> float:
    ''' 算式解析并计算 '''
    numbers = [] # 数值
    signs = [] # 运算符
    local_num = '' # 当前数值

    # 拆分算式
    for char in s:
        if char.isdigit() or char=='.':
            local_num += char
        else:
            numbers.append(float(local_num))
            signs.append(char)
            local_num = ''

    numbers.append(float(local_num)) # 追加最后一个数值

    # 计算乘除
    newnumbers = numbers[:1]
    for i in range(1, len(numbers)):
        if signs[i-1] == '*':
            newnumbers[-1] = newnumbers[-1] * numbers[i]
            signs[i-1] = ''
        elif signs[i-1] == '/':
            newnumbers[-1] = newnumbers[-1] /numbers[i]
            signs[i-1] = ''
        else:
            newnumbers.append(numbers[i])
    signs = [sign for sign in signs if sign] # 更新运算符列表

    # 处理+、-符号:列表解析,用前插空字符对齐运算符与数值列表,遍历zip拼接“运算符-数值”对,更新到newnumbers
    newnumbers = [float(f"{number[0]}{number[1]}") for number in zip(['']+signs, newnumbers)]
    return sum(newnumbers) # 求和(加)并返回


def calculate(s:str) -> float:
    ''' 算式解析并计算 '''
    s = [float(part) if part.replace('.', '').isdigit() else part for part in split_expression(s)] # 三元操作语句列表解析数值

    # 算乘除
    k = 1
    while k < len(s)-1:
        if s[k] == '*':
            s[k-1] = s[k-1]*s.pop(k+1) # 用积重写乘号前数值
            s.pop(k) # 删除乘号
        elif s[k] == '/':
            s[k-1] = s[k-1]/s.pop(k+1) # 用商重写乘号前数值
            s.pop(k) # 删除乘号
        else:
            k += 1 # 跳过加减运算符和数值

    # 算加减
    k = 1
    while k < len(s)-1:
        if s[k] == '+':
            s[k-1] = s[k-1] + s.pop(k+1) # 用和重写加号前数值
            s.pop(k) # 删除加号
        elif s[k] == '-':
            s[k-1] = s[k-1]- s.pop(k+1) # 用和重写加号前数值
            s.pop(k) # 删除减号
        else:
            k += 1 # 跳过数值

    return s[0] # 返回计算结果


def calculator(s:str) -> float:
    ''' 计算器 '''
    result = calculate(s) # 调用计算解析函数
    return int(result) if round(result) == result else result # 结果是整,去尾0


def main() -> None:
    ''' 主程序 '''
    while True:
        clear = '\033[2J' # 清屏字符串(windows系统低版本不支持)
        print(f"\n{clear}")        
        text = input(f"\n{' 简单计算器 ':=^37}\n{'(不带括号的四则运算,输入00退出)':^26}\n\n\n{' 回车确认执行计算 ':-^34}\n\n{'输入算式:':>7}").strip()

        if text == '00':
            print(f"{clear}\n{' 您已退出“简单计算器”!':^33}\n\n{f' 谢谢您使用“简单计算器”。':-^31}\n")
            break # break更优雅

        validate_input(text) # 输入验证
        result = calculator(text) # 计算表达式
        input(f"\n\n{'结果:':>9}{result}\n\n\n{'':=^42}\n{'(任意键继续……)':^35}") 


if __name__ == '__main__':
    try:
        main() # 启动主程序
    except ValueError as e:
        print(e)


雏形版

#!/sur/bin/nve python3
# coding: utf-8


'''

简单计算器:处理没有括号的+-*/算式,可以实现四则混合运算仅支持0和自然数。

程序不调用库和模块,纯代码手撕。


'''


def validate_input(s:str) -> bool:
    ''' 输入验证 '''
    # expression空验证
    if not s:
        raise ValueError(f"\n{f' 算式不可为空 ':-^36}\n")    

    # 字符有效验证
    chars = tuple('0123456789+-/*.')
    for char in s:
        if char not in chars:
            raise ValueError(f"\n{f' 错误字符:{char} ':-^35}\n") 

    # expression末尾验证
    if not s[-1].isdigit():
        raise ValueError(f"\n{f' 算式末尾不可以是:{s[-1]} ':-^31}\n")    

    # 连续符号验证(用的是str.isdigit方法判定算式中的相邻两个字符)
    for i in range(1, len(s)):
        if not s[i-1].isdigit() and not s[i].isdigit():
            raise ValueError(f"\n{f' 算式不可以有连续符号:{s[i-1]}{s[i]} ':-^30}\n") 
    
    # 数值小数点验证:用str.count方法计数数值字符小数点。
    # 用空格替换加减乘除字符后,再用str.split拆分列表来对数值字符串预处理。
    for number in s.replace('+', ' ').replace('-', ' ').replace('*', ' ').replace('/', ' ').split():
        if number.count('.') > 1:
            raise ValueError(f"\n{f' “{number}”小数点错误。 ':-^36}\n") 

    return True


def calculate(s:str) -> float:
    ''' 算式解析并计算 '''
    numbers = [] # 数值
    signs = [] # 运算符
    local_num = '' # 当前数值

    # 拆分算式
    for char in s:
        if char.isdigit() or char=='.':
            local_num += char
        else:
            numbers.append(float(local_num))
            signs.append(char)
            local_num = ''

    numbers.append(float(local_num)) # 追加最后一个数值

    # 计算乘除
    newnumbers = numbers[:1]
    for i in range(1, len(numbers)):
        if signs[i-1] == '*':
            newnumbers[-1] = newnumbers[-1] * numbers[i]
            signs[i-1] = ''
        elif signs[i-1] == '/':
            newnumbers[-1] = newnumbers[-1] /numbers[i]
            signs[i-1] = ''
        else:
            newnumbers.append(numbers[i])
    signs = [sign for sign in signs if sign] # 更新运算符列表

    # 处理+、-符号:列表解析,用前插空字符对齐运算符与数值列表,遍历zip拼接“运算符-数值”对,更新到newnumbers
    newnumbers = [float(f"{number[0]}{number[1]}") for number in zip(['']+signs, newnumbers)]
    return sum(newnumbers) # 求和(加)并返回


def calculator(s:str) -> float:
    ''' 计算器 '''
    result = calculate(s) # 调用计算解析函数
    return int(result) if int(result) == result else result # 结果是整,去尾0


def main() -> None:
    ''' 主程序 '''
    while True:
        clear = '\033[2J' # 清屏字符串(windows系统低版本不支持)
        print(f"\n{clear}")        
        text = input(f"\n{' 简单计算器 ':=^37}\n{'(不带括号的四则运算,输入00退出)':^26}\n\n\n{' 回车确认执行计算 ':-^34}\n\n{'输入算式:':>7}").strip()

        if text == '00':
            print(f"{clear}\n{' 您已退出“简单计算器”!':^33}\n\n{f' 谢谢您使用“简单计算器”。':-^31}\n")
            break # break更优雅

        validate_input(text) # 输入验证
        result = calculator(text) # 计算表达式
        input(f"\n\n{'结果:':>7}{result}\n\n\n{'':=^42}\n{'(任意键继续……)':^35}") 


if __name__ == '__main__':
    try:
        main() # 启动主程序
    except ValueError as e:
        print(e)


修正版

#!/sur/bin/nve python3
# coding: utf-8


'''

简单计算器:处理没有括号的+-*/算式,可以实现四则混合运算仅支持0和自然数。

程序不调用库和模块,纯代码手撕。


'''


def validate_input(s:str) -> bool:
    ''' 输入验证 '''
    # expression空验证
    if not s:
        raise ValueError(f"\n{f' 算式不可为空 ':-^36}\n")    

    # 字符有效验证
    chars = tuple('0123456789+-/*.')
    for char in s:
        if char not in chars:
            raise ValueError(f"\n{f' 错误字符:{char} ':-^35}\n") 

    # expression末尾验证
    if not s[-1].isdigit():
        raise ValueError(f"\n{f' 算式末尾不可以是:{s[-1]} ':-^31}\n")    

    # 连续符号验证(用的是str.isdigit方法判定算式中的相邻两个字符)
    for i in range(1, len(s)):
        if not s[i-1].isdigit() and not s[i].isdigit():
            raise ValueError(f"\n{f' 算式不可以有连续符号:{s[i-1]}{s[i]} ':-^30}\n") 
    
    # 数值小数点验证:用str.count方法计数数值字符小数点。
    # 用空格替换加减乘除字符后,再用str.split拆分列表来对数值字符串预处理。
    for number in s.replace('+', ' ').replace('-', ' ').replace('*', ' ').replace('/', ' ').split():
        if number.count('.') > 1:
            raise ValueError(f"\n{f' “{number}”小数点错误。 ':-^36}\n") 

    return True


def calculate(s:str) -> float:
    ''' 算式解析并计算 '''
    numbers = [] # 数值
    signs = [] # 运算符
    local_num = '' # 当前数值

    # 拆分算式
    for char in s:
        if char.isdigit() or char=='.':
            local_num += char
        else:
            numbers.append(float(local_num))
            signs.append(char)
            local_num = ''

    numbers.append(float(local_num)) # 追加最后一个数值

    # 计算乘除
    newnumbers = numbers[:1]
    for i in range(1, len(numbers)):
        if signs[i-1] == '*':
            newnumbers[-1] = newnumbers[-1] * numbers[i]
            signs[i-1] = ''
        elif signs[i-1] == '/':
            newnumbers[-1] = newnumbers[-1] /numbers[i]
            signs[i-1] = ''
        else:
            newnumbers.append(numbers[i])
    signs = [sign for sign in signs if sign] # 更新运算符列表

    # 处理+、-符号:列表解析,用前插空字符对齐运算符与数值列表,遍历zip拼接“运算符-数值”对,更新到newnumbers
    newnumbers = [float(f"{number[0]}{number[1]}") for number in zip(['']+signs, newnumbers)]
    return sum(newnumbers) # 求和(加)并返回


def calculator(s:str) -> float:
    ''' 计算器 '''
    result = calculate(s) # 调用计算解析函数
    return int(result) if int(result) == result else result # 结果是整,去尾0


def main() -> None:
    ''' 主程序 '''
    while True:
        clear = '\033[2J' # 清屏字符串(windows系统低版本不支持)
        print(f"\n{clear}")        
        text = input(f"\n{' 简单计算器 ':=^37}\n{'(不带括号的四则运算,输入00退出)':^26}\n\n\n{' 回车确认执行计算 ':-^34}\n\n{'输入算式:':>7}").strip()

        if text == '00':
            print(f"{clear}\n{' 您已退出“简单计算器”!':^33}\n\n{f' 谢谢您使用“简单计算器”。':-^31}\n")
            break # break更优雅

        validate_input(text) # 输入验证
        result = calculator(text) # 计算表达式
        input(f"\n\n{'结果:':>7}{result}\n\n\n{'':=^42}\n{'(任意键继续……)':^35}") 


if __name__ == '__main__':
    try:
        main() # 启动主程序
    except ValueError as e:
        print(e)



回页首


上一篇:  Python的五种自定义类的“代码书写”形式(Python 中有五种自定义类写法,缺省参数或者指定metaclass可以自定义普通类;用元类作基类可以定义元类)
下一篇: 



我的HOT博:

  本次共计收集 311 篇博文笔记信息,总阅读量43.82w。数据于2024年03月22日 00:50:22完成采集,用时6分2.71秒。阅读量不小于6.00k的有 7 7 7篇。

  • 001
    标题:让QQ群昵称色变的神奇代码
    (浏览阅读 5.9w )
    地址:https://blog.csdn.net/m0_57158496/article/details/122566500
    点赞:25 收藏:86 评论:17
    摘要:让QQ昵称色变的神奇代码。
    首发:2022-01-18 19:15:08
    最后编辑:2022-01-20 07:56:47

  • 002
    标题:Python列表(list)反序(降序)的7种实现方式
    (浏览阅读 1.1w )
    地址:https://blog.csdn.net/m0_57158496/article/details/128271700
    点赞:8 收藏:35 评论:8
    摘要:Python列表(list)反序(降序)的实现方式:原址反序,list.reverse()、list.sort();遍历,全数组遍历、1/2数组遍历;新生成列表,resersed()、sorted()、负步长切片[::-1]。
    首发:2022-12-11 23:54:15
    最后编辑:2023-03-20 18:13:55

  • 003
    标题:pandas 数据类型之 DataFrame
    (浏览阅读 9.7k )
    地址:https://blog.csdn.net/m0_57158496/article/details/124525814
    点赞:7 收藏:36 
    摘要:pandas 数据类型之 DataFrame_panda dataframe。
    首发:2022-05-01 13:20:17
    最后编辑:2022-05-08 08:46:13

  • 004
    标题:个人信息提取(字符串)
    (浏览阅读 8.2k )
    地址:https://blog.csdn.net/m0_57158496/article/details/124244618
    点赞:2 收藏:15 
    摘要:个人信息提取(字符串)_个人信息提取python。
    首发:2022-04-18 11:07:12
    最后编辑:2022-04-20 13:17:54

  • 005
    标题:Python字符串居中显示
    (浏览阅读 7.6k )
    地址:https://blog.csdn.net/m0_57158496/article/details/122163023
    评论:1

  • 006
    标题:罗马数字转换器|罗马数字生成器
    (浏览阅读 7.5k )
    地址:https://blog.csdn.net/m0_57158496/article/details/122592047
    摘要:罗马数字转换器|生成器。
    首发:2022-01-19 23:26:42
    最后编辑:2022-01-21 18:37:46

  • 007
    标题:回车符、换行符和回车换行符
    (浏览阅读 6.0k )
    地址:https://blog.csdn.net/m0_57158496/article/details/123109488
    点赞:2 收藏:3 
    摘要:回车符、换行符和回车换行符_命令行回车符。
    首发:2022-02-24 13:10:02
    最后编辑:2022-02-25 20:07:40


推荐条件 阅读量突破6.00k
(更多热博,请点击蓝色文字跳转翻阅)

  • 截屏图片
    在这里插入图片描述
      (此文涉及ChatPT,曾被csdn多次下架,前几日又因新发笔记被误杀而落马。躺“未过审”还不如回收站,回收站还不如永久不见。😪值此年底清扫,果断移除。留此截图,以识“曾经”。2023-12-31)



回页首


老齐漫画头像

精品文章:

  • 好文力荐:齐伟书稿 《python 完全自学教程》 Free连载(已完稿并集结成书,还有PDF版本百度网盘永久分享,点击跳转免费🆓下载。)
  • OPP三大特性:封装中的property
  • 通过内置对象理解python'
  • 正则表达式
  • python中“*”的作用
  • Python 完全自学手册
  • 海象运算符
  • Python中的 `!=`与`is not`不同
  • 学习编程的正确方法

来源:老齐教室


◆ Python 入门指南【Python 3.6.3】


好文力荐:

  • 全栈领域优质创作者——[寒佬](还是国内某高校学生)博文“非技术文—关于英语和如何正确的提问”,“英语”和“会提问”是编程学习的两大利器。
  • 【8大编程语言的适用领域】先别着急选语言学编程,先看它们能干嘛
  • 靠谱程序员的好习惯
  • 大佬帅地的优质好文“函数功能、结束条件、函数等价式”三大要素让您认清递归

CSDN实用技巧博文:

  • 8个好用到爆的Python实用技巧
  • python忽略警告
  • Python代码编写规范
  • Python的docstring规范(说明文档的规范写法)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2159091.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

有关在.Net Core中以TEXT类型将Json格式字段存到数据库的学习

导言 在写个值日接口时发现值日表中的值日时段是可以分多段的&#xff0c;想了想可以使用Json类型来存&#xff0c;不过之前没接触过在后端操作Json格式存到数据库的情况&#xff0c;之后学也了解到了一下方法来实现&#xff0c;故记录一下。 过程 从前端到后端再到数据库的 JS…

图片切换示例【JavaScript】

在 JavaScript 中实现图片切换可以通过多种方法&#xff0c;下面是一个简单的示例&#xff0c;使用 HTML、CSS 和 JavaScript 来实现图片的切换效果。 实现效果&#xff1a; 代码&#xff1a; <!DOCTYPE html> <html lang"zh"><head><meta c…

VMware Workstation 17.5安装教程

目录 软件介绍 1、下载安装包 2、安装虚拟机 3、卸载虚拟机 软件介绍 VMware&#xff08;虚拟机&#xff09;是指通过软件模拟的具有完整硬件系统功能的、运行在一个完全隔离环境中的完整计算机系统&#xff0c;通过它可在一台电脑上同时运行更多的Microsoft Windows、Linux…

看Threejs好玩示例,学习创新与技术(React-three-fiber)

什么&#xff0c;竟有人把ThreeJS和React绑定在一起&#xff0c;混着用&#xff1f; 1、VUE劫持问题 暂先把今天的问题先放一边&#xff0c;先简单回顾下vue劫持的情况。vue会把data里面的数据自动转换为属性&#xff0c;方便界面与数据交互。这本身是没有任何问题&#xff0…

快手旗下——Kolors模型部署与使用指南

以下是按照要求重写后的 Kolors 模型部署与使用指南&#xff0c;文章风格偏技术性&#xff0c;但保持简洁和易懂的特点&#xff1a; Kolors 模型部署与使用指南 一、Kolors 简介 Kolors 是由快手 Kolors 团队开发的文本到图像生成模型&#xff0c;基于大规模的潜在扩散技术。…

找不到libcef.dll怎么办,libcef.dll丢失怎么重新安装

在计算机使用过程中&#xff0c;我们常常会遇到各种问题。其中&#xff0c;libcef.dll丢失是一个常见的错误提示。libcef.dll是Chromium Embedded Framework的动态链接库&#xff0c;它是许多应用程序和游戏所必需的组件。当libcef.dll丢失或损坏时&#xff0c;可能会导致程序无…

2025秋招内推|招联金融

【投递方式】 直接扫下方二维码&#xff0c;使用内推码: igcefb 【招聘岗位】 深圳&#xff0c;武汉&#xff1a; 后台开发 前端开发 数据开发 数据运营 算法开发 技术运维 软件测试 产品策划 产品运营 客户体验管理 风险管理 资产管理 【校招流程】 简历投递&#xff1a;9月…

死磕P7: JVM内存划分必知必会(一)

这是「死磕P7」系列第 001 篇文章&#xff0c;欢迎大家来跟我一起 死磕 100 天&#xff0c;争取在 2025 年来临之际&#xff0c;给自己一个交代。 JVM 内存区域划分是面试常考点&#xff0c;属于死记硬背型&#xff0c;比较让人头大的是不同版本的 JDK 具有不同的划分方式&…

计算机毕业设计 基于Python的医疗预约与诊断系统 Django+Vue 前后端分离 附源码 讲解 文档

&#x1f34a;作者&#xff1a;计算机编程-吉哥 &#x1f34a;简介&#xff1a;专业从事JavaWeb程序开发&#xff0c;微信小程序开发&#xff0c;定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事&#xff0c;生活就是快乐的。 &#x1f34a;心愿&#xff1a;点…

联合复现!考虑最优弃能率的风光火储联合系统分层优化经济调度!

前言 目前&#xff0c;尽管不断地追逐可再生能源全额消纳方式&#xff0c;大幅减小弃风弃光电量&#xff0c;但是若考虑风电、光伏发电的随机属性&#xff0c;全额消纳可能造成电网峰谷差、调峰难度及调峰调频等辅助服务费用的剧增&#xff0c;引起电网潜在运行风险。因此&…

英特尔AI加速器Gaudi 3下周发布,挑战NVIDIA统治地位!

英特尔正稳步推进其2024年计划&#xff0c;备受瞩目的AI加速器Gaudi3预计将于下周震撼登场。这款被誉为英特尔AI英雄的产品&#xff0c;专注于处理大规模训练和推理任务&#xff0c;拥有无与伦比的扩展能力。面对市场对高效能半导体的旺盛需求&#xff0c;英特尔首席执行官帕特…

Snap 发布新一代 AR 眼镜,有什么特别之处?

Snap 发布新一代 AR 眼镜&#xff0c;有什么特别之处&#xff1f; Snap 简介 新一代的 AR 眼镜特点 Snap 简介 Snap 公司成立于 2010 年&#xff0c;2017 年美国东部时间 3 月 2 日上午 11 时许&#xff0c;在纽交所正式挂牌交易&#xff0c;股票代码为 “SNAP”。其旗下的核…

力扣 2529.正整数和负整数的最大计数

文章目录 题目介绍解法 题目介绍 解法 采用红蓝染色体法&#xff0c;具体介绍参考 红蓝染色体法 通过红蓝染色体法可以找到第一个大于大于target的位置&#xff0c;使所以本题可以找第一个大于0的位置&#xff0c;即负整数的个数&#xff1b;数组长度 - 第一个大于1的位置即正…

2000-2012年各地级市市长特征信息数据/市长特征信息大全数据

2000-2012年各地级市市长特征信息数据 1、时间&#xff1a;2000-2012年 2、来源&#xff1a;百度搜索手工整理 3、指标&#xff1a;省级政区代码、省级政区名称、地市级政区代码、地市级政区名称、年份、市长姓名、出生年份、出生月份、籍贯省份代码、籍贯省份名称、籍贯地市…

垃圾邮件检测_TF-IDF分析,聚类分析与朴素贝叶斯

数据入口&#xff1a;基于机器学习的垃圾信息识别分类 - Heywhale.com 本数据集专为邮件和短信的垃圾信息分类设计&#xff0c;适合建立垃圾邮件检测模型。 数据说明 字段名说明message_content邮件或短信的正文内容is_spam标签&#xff0c;指示该消息是否为垃圾信息&#x…

恒生科指八连涨,汽车股强势

9月20日电 周五&#xff0c;港股三大股指集体收涨。恒生指数涨1.36%报18258.57点&#xff0c;连续第六个交易日上涨&#xff1b;恒生科技指数涨1.43%报3703.84点&#xff0c;连续第八个交易日上涨&#xff0c;创逾两个月来新高&#xff1b;恒生中国企业指数涨1.21%报6381.5点&a…

Set 和 Map 的模拟实现

1、引言 在数据结构与算法的学习与实践中&#xff0c;关联容器&#xff08;associative containers&#xff09;是不可忽视的重要工具。作为高效管理数据的一类容器&#xff0c;C 标准库中的 set 和 map 在现代软件开发中扮演着关键角色。这两个容器通过平衡二叉搜索树&#x…

c++类中的特殊函数

My_string.cpp #include <iostream> #include "my_string.h" #include <string.h> using namespace std; My_string::My_string():size(15) { this->ptr new char[size] ; this->ptr[0]\0;//串为空串 this->len 0; }; My_string::My_str…

Leetcode3289. 数字小镇中的捣蛋鬼

Every day a Leetcode 题目来源&#xff1a;3289. 数字小镇中的捣蛋鬼 解法1&#xff1a;哈希 代码&#xff1a; /** lc appleetcode.cn id3289 langcpp** [3289] 数字小镇中的捣蛋鬼*/// lc codestart class Solution { public:vector<int> getSneakyNumbers(vector…