最近在学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 - 计算个人所得税的更多相关文章

  1. 【Python】个人所得税

    以月收入1w,举例计算个税: #!/usr/bin/python #-*- encoding:UTF-8 -*- #========================================== ...

  2. [转载] python 计算字符串长度

    本文转载自: http://www.sharejs.com/codes/python/4843 python 计算字符串长度,一个中文算两个字符,先转换成utf8,然后通过计算utf8的长度和len函 ...

  3. Python计算斗牛游戏的概率

    Python计算斗牛游戏的概率 过年回家,都会约上亲朋好友聚聚会,会上经常会打麻将,斗地主,斗牛.在这些游戏中,斗牛是最受欢迎的,因为可以很多人一起玩,而且没有技术含量,都是看运气(专业术语是概率). ...

  4. 利用Python计算π的值,并显示进度条

    利用Python计算π的值,并显示进度条  第一步:下载tqdm 第二步;编写代码 from math import * from tqdm import tqdm from time import ...

  5. 用Python计算幂的两种方法,非递归和递归法

    用Python计算幂的两种方法: #coding:utf-8 #计算幂的两种方法.py #1.常规方法利用函数 #不使用递归计算幂的方法 """ def power(x, ...

  6. Python计算分位数

    Python计算分位数    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/gdkyxy2013/article/details/80911514 ...

  7. python 计算校验和

    校验和是经常使用的,这里简单的列了一个针对按字节计算累加和的代码片段.其实,这种累加和的计算,将字节翻译为无符号整数和带符号整数,结果是一样的. 使用python计算校验和时记住做截断就可以了. 这里 ...

  8. 为了用python计算一个汉字的中心点,差点没绞尽脑汁活活累死

    为了用python计算一个汉字的中心点,差点没绞尽脑汁活活累死

  9. python计算时间差的方法

    本文实例讲述了python计算时间差的方法.分享给大家供大家参考.具体分析如下: 1.问题: 给定你两个日期,如何计算这两个日期之间间隔几天,几个星期,几个月,几年? 2.解决方法: 标准模块date ...

随机推荐

  1. 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 ...

  2. yolo详解

    文章<You Only Look Once: Unified, Real-Time Object Detection>提出方法下面简称YOLO. 目前,基于深度学习算法的一系列目标检测算法 ...

  3. Golang的文件处理方式-常见的读写姿势

    Golang的文件处理方式-常见的读写姿势 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 在 Golang 语言中,文件使用指向 os.File 类型的指针来表示的,也叫做文件句柄 ...

  4. 001. MyBatis+SpringMVC+Spring[重置版]

    说在前面的话 三阶段的课程知识点和细节很多,请假应该杜绝! 课后需抓紧时间复习,提高代码质量和速度! 课程周期和学习课程顺序为:[正常情况下] MyBatis 持久层框架 [2周] SpringMVC ...

  5. SpringBoot 读取配置文件及profiles切换配置文件

    读取核心配置文件 核心配置文件是指在resources根目录下的application.properties或application.yml配置文件,读取这两个配置文件的方法有两种,都比较简单. 先创 ...

  6. spring框架学习(二)使用注解代替xml配置

    注解 1.使用注解配置spring 1)开启使用注解代理配置文件 <?xml version="1.0" encoding="UTF-8"?> &l ...

  7. [转载]jdk环境变量配置方法

    JDK下载 在安装完jdk后,还需要对jdk的环境变量进行配置才能正常使用,下面教大家如何配置jdk环境变量: 1.右键选择 计算机→属性→高级系统设置→高级→环境变量 2.系统变量→新建 变量名:J ...

  8. 【转】XMPP_3920_最靠谱的中文翻译文档

    CHENYILONG Blog XMPP_3920_最靠谱的中文翻译文档 Fullscreen © chenyilong. Powered by Postach.io Blog

  9. lemon spj无效编译器解决方法

    反正我是被坑了很久,心里增的敲难过呀! 我曾经无数次的想把它解决掉: 啊啊啊啊啊啊! 什么嘛!什么嘛! 这个空白的框框里到底要填什么嘛!!! 你已经是一个成熟的lemon了,就不能自动识别给个选项吗! ...

  10. 关于python开发CRM系统

    注意本项目是针对培训学校开发简化的CRM CRM简介 CRM全称:customer relationship management 无CRM的痛点 没有CMR的缺点及痛点: 每个销售会通过Excel来 ...