Python - 计算个人所得税
最近在学python,写了个计算个人所得税计算的脚本,分享。
以下为python3适用版本
#!/usr/bin/python # -*- coding: UTF-8 -*- # 该python脚本用于计算税后工资 # 提示用户输入工资 sal = input("Please input your salary: \n") # 自定义一个异常 class MyException(Exception): def __init__(self, *args): self.args = args try: sal = int(sal) if sal < 0: raise MyException except ValueError: print("给劳资输一个整数,别带字母和小数!\n") except MyException: print("你大爷的,工资是负数?\n") else: # 计算社保和公积金以及扣除该部分之后的工资 shebao = round(sal * 0.105, 2) gongjijin = round(sal * 0.07, 2) aft_sal = sal - shebao - gongjijin # 税率(这个没变) sui_lv = [0.45, 0.35, 0.3, 0.25, 0.2, 0.1, 0.03] # 税改前超出起征点各阶段工资 jin_e1 = [80000, 55000, 35000, 9000, 4500, 1500, 0] # 税改后超出起征点各阶段工资 jin_e2 = [80000, 55000, 35000, 25000, 12000, 3000, 0] # 起征点(调整前3500,调整后5000) qizheng1 = 3500 qizheng2 = 5000 # 应缴税工资:税前工资-社保-公积金-起征点 yinjiao1 = aft_sal - qizheng1 yinjiao2 = aft_sal - qizheng2 # 定义计算所得税函数 # a应缴税工资,b超出起征点各阶段工资,c税率 def jisuan(a, b, c): sum = 0 for i in range(0, len(b)): if a > b[i]: sum += (a - b[i]) * c[i] a = b[i] return round(sum, 2) # 计算所得税 suodesui1 = jisuan(yinjiao1, jin_e1, sui_lv) suodesui2 = jisuan(yinjiao2, jin_e2, sui_lv) print("\n税前月收入: {}".format(sal)) print("五险一金: {}".format(shebao + gongjijin)) print("旧税率应纳税: {} 元,税后收入: {} 元".format(suodesui1, round(aft_sal-suodesui1, 2))) print("新税率应纳税: {} 元,税后收入: {} 元\n".format(suodesui2, round(aft_sal-suodesui2, 2)))
--------------------------------------------------------分割线------------------------------------------------------------------------------------
以下为python2适用的版本
#!/usr/bin/python # -*- coding: UTF-8 -*- # 该python脚本用于计算税后工资 # 提示用户输入工资 sal = raw_input("Please input your salary: \n") # 自定义一个异常 class MyException(Exception): def __init__(self, *args): self.args = args try: sal = int(sal) if sal < 0: raise MyException except ValueError: print("给劳资输一个整数,别带字母和小数!\n") except MyException: print("你大爷的,工资是负数?\n") else: # 计算社保和公积金以及扣除该部分之后的工资 shebao = round(sal * 0.105, 2) gongjijin = round(sal * 0.07, 2) aft_sal = sal - shebao - gongjijin # 税率(这个没变) sui_lv = [0.45, 0.35, 0.3, 0.25, 0.2, 0.1, 0.03] # 税改前超出起征点各阶段工资 jin_e1 = [80000, 55000, 35000, 9000, 4500, 1500, 0] # 税改后超出起征点各阶段工资 jin_e2 = [80000, 55000, 35000, 25000, 12000, 3000, 0] # 起征点(调整前3500,调整后5000) qizheng1 = 3500 qizheng2 = 5000 # 应缴税工资:税前工资-社保-公积金-起征点 yinjiao1 = aft_sal - qizheng1 yinjiao2 = aft_sal - qizheng2 # 定义计算所得税函数 # a应缴税工资,b超出起征点各阶段工资,c税率 def jisuan(a, b, c): sum = 0 for i in range(0, len(b)): if a > b[i]: sum += (a - b[i]) * c[i] a = b[i] return round(sum, 2) # 计算所得税 suodesui1 = jisuan(yinjiao1, jin_e1, sui_lv) suodesui2 = jisuan(yinjiao2, jin_e2, sui_lv) print("\n税前月收入: %d" % sal) print("五险一金: %.2f" % (shebao + gongjijin)) print("旧税率应纳税: %.2f 元,税后收入: %.2f 元" % (suodesui1, (aft_sal-suodesui1))) print("新税率应纳税: %.2f 元,税后收入: %.2f 元\n" % (suodesui2, (aft_sal-suodesui2)))
Python - 计算个人所得税的更多相关文章
- 【Python】个人所得税
以月收入1w,举例计算个税: #!/usr/bin/python #-*- encoding:UTF-8 -*- #========================================== ...
- [转载] python 计算字符串长度
本文转载自: http://www.sharejs.com/codes/python/4843 python 计算字符串长度,一个中文算两个字符,先转换成utf8,然后通过计算utf8的长度和len函 ...
- Python计算斗牛游戏的概率
Python计算斗牛游戏的概率 过年回家,都会约上亲朋好友聚聚会,会上经常会打麻将,斗地主,斗牛.在这些游戏中,斗牛是最受欢迎的,因为可以很多人一起玩,而且没有技术含量,都是看运气(专业术语是概率). ...
- 利用Python计算π的值,并显示进度条
利用Python计算π的值,并显示进度条 第一步:下载tqdm 第二步;编写代码 from math import * from tqdm import tqdm from time import ...
- 用Python计算幂的两种方法,非递归和递归法
用Python计算幂的两种方法: #coding:utf-8 #计算幂的两种方法.py #1.常规方法利用函数 #不使用递归计算幂的方法 """ def power(x, ...
- Python计算分位数
Python计算分位数 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/gdkyxy2013/article/details/80911514 ...
- python 计算校验和
校验和是经常使用的,这里简单的列了一个针对按字节计算累加和的代码片段.其实,这种累加和的计算,将字节翻译为无符号整数和带符号整数,结果是一样的. 使用python计算校验和时记住做截断就可以了. 这里 ...
- 为了用python计算一个汉字的中心点,差点没绞尽脑汁活活累死
为了用python计算一个汉字的中心点,差点没绞尽脑汁活活累死
- python计算时间差的方法
本文实例讲述了python计算时间差的方法.分享给大家供大家参考.具体分析如下: 1.问题: 给定你两个日期,如何计算这两个日期之间间隔几天,几个星期,几个月,几年? 2.解决方法: 标准模块date ...
随机推荐
- POJ 1502 MPI Maelstrom / UVA 432 MPI Maelstrom / SCU 1068 MPI Maelstrom / UVALive 5398 MPI Maelstrom /ZOJ 1291 MPI Maelstrom (最短路径)
POJ 1502 MPI Maelstrom / UVA 432 MPI Maelstrom / SCU 1068 MPI Maelstrom / UVALive 5398 MPI Maelstrom ...
- yolo详解
文章<You Only Look Once: Unified, Real-Time Object Detection>提出方法下面简称YOLO. 目前,基于深度学习算法的一系列目标检测算法 ...
- Golang的文件处理方式-常见的读写姿势
Golang的文件处理方式-常见的读写姿势 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 在 Golang 语言中,文件使用指向 os.File 类型的指针来表示的,也叫做文件句柄 ...
- 001. MyBatis+SpringMVC+Spring[重置版]
说在前面的话 三阶段的课程知识点和细节很多,请假应该杜绝! 课后需抓紧时间复习,提高代码质量和速度! 课程周期和学习课程顺序为:[正常情况下] MyBatis 持久层框架 [2周] SpringMVC ...
- SpringBoot 读取配置文件及profiles切换配置文件
读取核心配置文件 核心配置文件是指在resources根目录下的application.properties或application.yml配置文件,读取这两个配置文件的方法有两种,都比较简单. 先创 ...
- spring框架学习(二)使用注解代替xml配置
注解 1.使用注解配置spring 1)开启使用注解代理配置文件 <?xml version="1.0" encoding="UTF-8"?> &l ...
- [转载]jdk环境变量配置方法
JDK下载 在安装完jdk后,还需要对jdk的环境变量进行配置才能正常使用,下面教大家如何配置jdk环境变量: 1.右键选择 计算机→属性→高级系统设置→高级→环境变量 2.系统变量→新建 变量名:J ...
- 【转】XMPP_3920_最靠谱的中文翻译文档
CHENYILONG Blog XMPP_3920_最靠谱的中文翻译文档 Fullscreen © chenyilong. Powered by Postach.io Blog
- lemon spj无效编译器解决方法
反正我是被坑了很久,心里增的敲难过呀! 我曾经无数次的想把它解决掉: 啊啊啊啊啊啊! 什么嘛!什么嘛! 这个空白的框框里到底要填什么嘛!!! 你已经是一个成熟的lemon了,就不能自动识别给个选项吗! ...
- 关于python开发CRM系统
注意本项目是针对培训学校开发简化的CRM CRM简介 CRM全称:customer relationship management 无CRM的痛点 没有CMR的缺点及痛点: 每个销售会通过Excel来 ...