Simple Calculator(简单计算器:算法初阶,代码基础,“纯”手撕)

news2024/11/16 21:34:19

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


(笔记模板由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/2170834.html

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

相关文章

负载均衡--相关面试题(六)

在负载均衡的面试中&#xff0c;可能会遇到一系列涉及概念、原理、实践应用以及技术细节的问题。以下是一些常见的负载均衡面试题及其详细解答&#xff1a; 一、什么是负载均衡&#xff1f; 回答&#xff1a;负载均衡是一种将网络请求或数据传输工作分配给多个服务器或网络资源…

微服务SpringSession解析部署使用全流程

1、SpringSession简介 是SpringCloud下管理session的框架&#xff0c;在微服务架构中&#xff0c;由于应用了分布式的思想&#xff0c;session无法做到内存中互通&#xff0c;需要一个框架来实现各个微服务中session数据共享&#xff0c;SpringSession解决了这个问题。 在Spr…

信息技术网络安全政策制定

为什么要制定网络安全政策&#xff1f; 通常&#xff0c;公司并不认为需要制定网络安全政策。现有的政策是为了保护公司的资产&#xff0c;而数据也是一项资产。 网络安全政策的真正必要性很简单&#xff1a;网络安全并不像锁门或不偷公司笔那么简单。在许多情况下&#xff0…

【Gitee自动化测试3】Git的本地使用,连接推送至Gitee上的仓库中

一. 创建版本库 存放项目&#xff0c;项目的删除更改&#xff0c;版本库都能够监控。 创建一个文件夹&#xff08;不要包含中文路径&#xff09;&#xff0c;右键选择Git Bash Here&#xff08;打开Git终端&#xff09; 输入git init 对文件夹进行版本库的初始化&#xff0c;…

汽车信息安全 -- 存到HSM中的密钥还需包裹吗?

目录 1.车规芯片的ROM_KEY 2.密钥加密与包裹 3.瑞萨RZ\T2M的密钥导入 4.小结 在车控类ECU中&#xff0c;我们通常把主控芯片MCU中的HSM以及HSM固件统一看做整个系统安全架构的信任根。 所以大家默认在HSM内部存储的数据等都是可信的&#xff0c;例如CycurHSM方案中使用HSM…

Win11家庭版升级专业版

参考&#xff1a; 小白升级--Win11家庭版到专业版_windows11家庭版升级专业版 csdn 82xm6-CSDN博客https://blog.csdn.net/weixin_45877306/article/details/136423462 这里&#xff0c;我步骤更简单点。 密钥&#xff1a;82XM6-23JJG-44W4Q-W3QPQ-V9FY4 到这里 等待就好。 …

Techub专访顾荣辉教授:解密CertiK的安全战略路线

当 Web3 安全审计公司还在争抢审计份额时&#xff0c;CertiK 已经开始将目光瞄准即将进军 Web3 的传统商业巨头。CertiK 不仅在传统行业进行白帽行动获得如苹果公司的官方感谢&#xff0c;还是 Web3 行业唯一一家拥有 SOC 2 和 ISO 认证的 Web3 的安全公司。基于此&#xff0c;…

APP集成人脸识别接口-C#人脸识别API接口

人脸识别技术是一种基于生物特征的识别技术&#xff0c;它通过捕捉和分析人脸特征来识别或验证个体身份。这项技术主要依赖于计算机视觉、图像处理和人工智能算法的结合&#xff0c;一般由第三方人工智能接口平台来提供&#xff0c;例如&#xff1a;翔云、阿里云等平台。 人脸识…

MySql在更新操作时引入“两阶段提交”的必要性

日志模块有两个redo log和binlog&#xff0c;redo log 是引擎层的日志&#xff08;负责存储相关的事&#xff09;&#xff0c;binlog是在Server层&#xff0c;主要做MySQL共嗯那个层面的事情。redo log就像一个缓冲区&#xff0c;可以让当更新操作的时候先放redo log中&#xf…

选择更轻松:山海鲸可视化与PowerBI的深度对比

在数据分析与可视化的时代&#xff0c;选择合适的报表工具显得尤为重要。山海鲸可视化和PowerBI是市场上颇受欢迎的两款免费报表软件&#xff0c;各有特色。接下来&#xff0c;我们将从功能、优缺点等方面进行对比&#xff0c;帮助你找到最适合的工具。 山海鲸可视化 山海鲸可…

台式机通过笔记本上网

概述: ①将wifi共享给网口 ②网口配置成自协商IP和DNS即可 一、背景 由于台式机只有网口&#xff0c;没得wifi网卡&#xff0c;因此想通过笔记本连wifi,再通过网线将笔记本和台式机连接起来&#xff0c;从而实现台式机通过笔记本的wifi上网&#xff0c;即让笔记本当台式机的…

闭环Token的创新机遇:如何通过控制和定制Token使用提升应用价值

闭环token&#xff08;Closed-Loop Tokens&#xff0c;简称CLTs&#xff09;允许在Sui上创建具有定义规则和限制的token&#xff0c;从而实现闭环token系统的创建。与Sui的Coin标准不同&#xff0c;后者允许无限制的使用和转移&#xff0c;而CLTs提供了一种更可控和可定制的方法…

梦到去世的亲人、朋友,多半是这三种暗示!

原创 国学君 国学人生 2024年09月27日 06:00 浙江 梦境一直是人类探索自我内心、情感和潜意识的神秘窗口。 尤其是梦到已故的亲人或朋友&#xff0c;这种情景不仅让人感到惊讶&#xff0c;更引发了深刻的思考。 在这些梦中&#xff0c;往往蕴含着重要的暗示。 本文将探讨梦…

傅里叶变换(对称美)

傅里叶变换&#xff08;对称美&#xff09; 冲浪时发现的有趣文章&#xff0c;学习自https://zhuanlan.zhihu.com/p/718139299 摘下来的内容&#xff1a; 傅里叶变换之所以“怪美的嘞”&#xff0c;根本在于它有一种内在的对称性&#xff0c;这一点在上面的图并没有表现出来…

UPS电池监控系统,蓄电池监控,提升电力保障的关键@卓振思众

在当今数字化和智能化迅速发展的时代&#xff0c;电力供应的可靠性变得尤为重要。无论是数据中心、金融机构还是医疗设施&#xff0c;稳定的电源保障都是运营的基石。因此&#xff0c;不间断电源&#xff08;UPS&#xff09;系统的有效管理显得尤为关键&#xff0c;而UPS电池监…

【樱花——公式推导,约数个数】

题目 思路 条件是一个等式&#xff0c;那么我们可以用一个变量k来表示x,y两个变量 首先&#xff0c;易知 x , y > n ! x, y > n! x,y>n!令 y n ! k , k ∈ Z yn!k, \;k \in Z_{} yn!k,k∈Z​代入原方程&#xff0c;得到参数方程组 { x n ! ( n ! ) 2 k y n…

expressjs集成swagger文档express-swagger-generator注释配置写法,query传参body传参

expressjs集成swagger文档及注释配置写法&#xff0c;query传参body传参 安装swagger依赖包 npm install express-swagger-generator app.js中初始化 const expressSwagger require(express-swagger-generator);let options {swaggerDefinition: {info: {description: Th…

原码反码补码移码

仅对数值位从右到左顺序扫描&#xff0c;右起第一个1及其右边的0保持不变&#xff0c;其余各位取反 [X补]全部位按位取反末位加1[-X补] [X补]符号位相反[X移] 对真值0具有唯一形式的机器数(机器码)是&#xff08;移码和补码&#xff09; 8位补码可以表示的最小负数为-128 1…

Jquery的Canvas交互式表格示例

在 <head> 中添加了 CSS 样式定义&#xff0c;包括 #inputbox 的样式。创建了一个 <div id"container"> 来包含 Canvas 和我们将要添加的单元格元素。#inputbox 样式设置为半透明黄色背景和黑色边框 <!DOCTYPE html> <html lang"zh"&…

在IntelliJ IDEA中设置文件自动定位

当然&#xff0c;以下是一个整理成博客格式的内容&#xff0c;关于如何在IntelliJ IDEA中设置文件自动定位功能。 在IntelliJ IDEA中设置文件自动定位 背景 最近由于公司项目开发的需求&#xff0c;我从VSCode转到了IntelliJ IDEA。虽然IDEA提供了许多强大的功能&#xff0c;…