用银行卡号查相应的归属银行,卡种类

项目场景:

用银行卡号查相应的归属银行,卡种类


问题描述:

    有同事需要用银行卡号查相应的归属银行,卡种类

方法思路:

  1. 直接查银行卡的网站用爬虫破解付款限制批量查询:难过试了很多次我压根不太会
  2. 调用现成的接口查询(0.0,这个还是可以的)
    这里用的是支付宝的接口< url = “https://ccdcapi.alipay.com/validateAndCacheCardInfo.json”>

完整代码:

完整代码:

import requests
import xlrd
import os
import xlsxwriter
import tkinter.messagebox

bank_abb = {
  "SRCB": "深圳农村商业银行",
  "BGB": "广西北部湾银行",
  "SHRCB": "上海农村商业银行",
  "BJBANK": "北京银行",
  "WHCCB": "威海市商业银行",
  "BOZK": "周口银行",
  "KORLABANK": "库尔勒市商业银行",
  "SPABANK": "平安银行",
  "SDEB": "顺德农商银行",
  "HURCB": "湖北省农村信用社",
  "WRCB": "无锡农村商业银行",
  "BOCY": "朝阳银行",
  "CZBANK": "浙商银行",
  "HDBANK": "邯郸银行",
  "BOC": "中国银行",
  "BOD": "东莞银行",
  "CCB": "中国建设银行",
  "ZYCBANK": "遵义市商业银行",
  "SXCB": "绍兴银行",
  "GZRCU": "贵州省农村信用社",
  "ZJKCCB": "张家口市商业银行",
  "BOJZ": "锦州银行",
  "BOP": "平顶山银行",
  "HKB": "汉口银行",
  "SPDB": "上海浦东发展银行",
  "NXRCU": "宁夏黄河农村商业银行",
  "NYNB": "广东南粤银行",
  "GRCB": "广州农商银行",
  "BOSZ": "苏州银行",
  "HZCB": "杭州银行",
  "HSBK": "衡水银行",
  "HBC": "湖北银行",
  "JXBANK": "嘉兴银行",
  "HRXJB": "华融湘江银行",
  "BODD": "丹东银行",
  "AYCB": "安阳银行",
  "EGBANK": "恒丰银行",
  "CDB": "国家开发银行",
  "TCRCB": "江苏太仓农村商业银行",
  "NJCB": "南京银行",
  "ZZBANK": "郑州银行",
  "DYCB": "德阳商业银行",
  "YBCCB": "宜宾市商业银行",
  "SCRCU": "四川省农村信用",
  "KLB": "昆仑银行",
  "LSBANK": "莱商银行",
  "YDRCB": "尧都农商行",
  "CCQTGB": "重庆三峡银行",
  "FDB": "富滇银行",
  "JSRCU": "江苏省农村信用联合社",
  "JNBANK": "济宁银行",
  "CMB": "招商银行",
  "JINCHB": "晋城银行JCBANK",
  "FXCB": "阜新银行",
  "WHRCB": "武汉农村商业银行",
  "HBYCBANK": "湖北银行宜昌分行",
  "TZCB": "台州银行",
  "TACCB": "泰安市商业银行",
  "XCYH": "许昌银行",
  "CEB": "中国光大银行",
  "NXBANK": "宁夏银行",
  "HSBANK": "徽商银行",
  "JJBANK": "九江银行",
  "NHQS": "农信银清算中心",
  "MTBANK": "浙江民泰商业银行",
  "LANGFB": "廊坊银行",
  "ASCB": "鞍山银行",
  "KSRB": "昆山农村商业银行",
  "YXCCB": "玉溪市商业银行",
  "DLB": "大连银行",
  "DRCBCL": "东莞农村商业银行",
  "GCB": "广州银行",
  "NBBANK": "宁波银行",
  "BOYK": "营口银行",
  "SXRCCU": "陕西信合",
  "GLBANK": "桂林银行",
  "BOQH": "青海银行",
  "CDRCB": "成都农商银行",
  "QDCCB": "青岛银行",
  "HKBEA": "东亚银行",
  "HBHSBANK": "湖北银行黄石分行",
  "WZCB": "温州银行",
  "TRCB": "天津农商银行",
  "QLBANK": "齐鲁银行",
  "GDRCC": "广东省农村信用社联合社",
  "ZJTLCB": "浙江泰隆商业银行",
  "GZB": "赣州银行",
  "GYCB": "贵阳市商业银行",
  "CQBANK": "重庆银行",
  "DAQINGB": "龙江银行",
  "CGNB": "南充市商业银行",
  "SCCB": "三门峡银行",
  "CSRCB": "常熟农村商业银行",
  "SHBANK": "上海银行",
  "JLBANK": "吉林银行",
  "CZRCB": "常州农村信用联社",
  "BANKWF": "潍坊银行",
  "ZRCBANK": "张家港农村商业银行",
  "FJHXBC": "福建海峡银行",
  "ZJNX": "浙江省农村信用社联合社",
  "LZYH": "兰州银行",
  "JSB": "晋商银行",
  "BOHAIB": "渤海银行",
  "CZCB": "浙江稠州商业银行",
  "YQCCB": "阳泉银行",
  "SJBANK": "盛京银行",
  "XABANK": "西安银行",
  "BSB": "包商银行",
  "JSBANK": "江苏银行",
  "FSCB": "抚顺银行",
  "HNRCU": "河南省农村信用",
  "COMM": "交通银行",
  "XTB": "邢台银行",
  "CITIC": "中信银行",
  "HXBANK": "华夏银行",
  "HNRCC": "湖南省农村信用社",
  "DYCCB": "东营市商业银行",
  "ORBANK": "鄂尔多斯银行",
  "BJRCB": "北京农村商业银行",
  "XYBANK": "信阳银行",
  "ZGCCB": "自贡市商业银行",
  "CDCB": "成都银行",
  "HANABANK": "韩亚银行",
  "CMBC": "中国民生银行",
  "LYBANK": "洛阳银行",
  "GDB": "广东发展银行",
  "ZBCB": "齐商银行",
  "CBKF": "开封市商业银行",
  "H3CB": "内蒙古银行",
  "CIB": "兴业银行",
  "CRCBANK": "重庆农村商业银行",
  "SZSBK": "石嘴山银行",
  "DZBANK": "德州银行",
  "SRBANK": "上饶银行",
  "LSCCB": "乐山市商业银行",
  "JXRCU": "江西省农村信用",
  "ICBC": "中国工商银行",
  "JZBANK": "晋中市商业银行",
  "HZCCB": "湖州市商业银行",
  "NHB": "南海农村信用联社",
  "XXBANK": "新乡银行",
  "JRCB": "江苏江阴农村商业银行",
  "YNRCC": "云南省农村信用社",
  "ABC": "中国农业银行",
  "GXRCU": "广西省农村信用",
  "PSBC": "中国邮政储蓄银行",
  "BZMD": "驻马店银行",
  "ARCU": "安徽省农村信用社",
  "GSRCU": "甘肃省农村信用",
  "LYCB": "辽阳市商业银行",
  "JLRCU": "吉林农信",
  "URMQCCB": "乌鲁木齐市商业银行",
  "XLBANK": "中山小榄村镇银行",
  "CSCB": "长沙银行",
  "JHBANK": "金华银行",
  "BHB": "河北银行",
  "NBYZ": "鄞州银行",
  "LSBC": "临商银行",
  "BOCD": "承德银行",
  "SDRCU": "山东农信",
  "NCB": "南昌银行",
  "TCCB": "天津银行",
  "WJRCB": "吴江农商银行",
  "CBBQS": "城市商业银行资金清算中心",
  "HBRCU": "河北省农村信用社",}

cardTypeMap = {
'DC': "储蓄卡",
'CC': "信用卡",
'SCC': "准贷记卡",
'PC': "预付费卡"
};
def get_bank(cardNo):
    url = "https://ccdcapi.alipay.com/validateAndCacheCardInfo.json"
    params = {
        "_input_charset": "utf-8",
        "cardNo": cardNo,
        "cardBinCheck": "true",
    }
    try:
        response=requests.get(url=url, params=params).json()
        bank = response["bank"]
        cardType=response["cardType"]
    except:
        return '银行卡号输入有误!'
    if bank in bank_abb.items() :
        print(bank_abb.items)
        return bank_abb[bank],cardTypeMap[cardType]

    else:
        return cardNo,bank_abb[bank],cardTypeMap[cardType]


def get_cardNo(cardNo_file_path, sheet_num=0):
    file_name = os.path.splitext(cardNo_file_path)[0]
    file_realname = file_name.split('\\')[-1]  # 文件名
    print(file_realname)
    exclename = file_name + '_get_info.xlsx'
    myWorkbook = xlsxwriter.Workbook(exclename)  # 创建一个excel文件,用于待会写数据
    sheet_file_realname = myWorkbook.add_worksheet(file_realname)  # 在文件中创建一个名为file_realname的sheet,不加名字默认为sheet1
    bold = myWorkbook.add_format({'bold': True})  # 设置一个加粗的格式对象
    workfomat = myWorkbook.add_format({
    'bold' : True,                 #字体加粗
    'border' : 1,                    #单元格边框宽度
    'align' : 'center',          #对齐方式
    'valign' : 'vcenter',         #字体对齐方式
    'fg_color' : '#F4B084',         #单元格背景颜色
    })
    sheet_file_realname.write(0, 0, u'银行卡', workfomat)  # 给第一行加标签
    sheet_file_realname.write(0, 1, u'归属银行', workfomat)
    sheet_file_realname.write(0, 2, u'种类', workfomat)

    # 设置读Excel的编码格式
    xlrd.Book.encoding = "gbk"
    rb = xlrd.open_workbook(cardNo_file_path)
    sheet = rb.sheet_by_index(sheet_num)  # 读第几个sheet,默认为第一个
    nrows = sheet.nrows
    print(nrows)
    for i in range(nrows):
        cardNo = sheet.cell_value(i, 0)
        if len(str(cardNo).replace(' ', ''))>=16 and len(str(cardNo).replace(' ', ''))<=19 :
            cardNo = sheet.cell_value(i, 0) # 假设电话号码在第一列,从第一行开始,也就是索引(0,0),
            if isinstance(cardNo,float):
                cardNo=str(int(phone_num)).replace(' ', '')

            else:
                cardNo=str(cardNo).replace(' ', '')
            cardNo_info = get_bank(cardNo)
            print('银行卡位数为:',len(cardNo_info[0]),cardNo_info)
            if len(cardNo_info[1])>1:
                sheet_file_realname.write(i + 1, 0, cardNo)
                sheet_file_realname.write(i + 1, 1, cardNo_info[1])
                sheet_file_realname.write(i + 1, 2, cardNo_info[2])
            else:
                sheet_file_realname.write(i + 1, 0, cardNo)
                sheet_file_realname.write(i + 1, 1, 'null')
                sheet_file_realname.write(i + 1, 2, 'null')

        else:
            sheet_file_realname.write(i + 1, 0, cardNo)
            sheet_file_realname.write(i + 1, 1, 'null')
            sheet_file_realname.write(i + 1, 2, 'null')

    myWorkbook.close()
    print(os.path.realpath(exclename))
    tkinter.messagebox.showinfo('新生新的文件路径', os.path.realpath(exclename))


if __name__ == "__main__":

    pwd = os.getcwd()
    cardNo_file_path = os.path.join(pwd,'银行卡账号.xlsx')
    # a=get_bank('621xx9xx02xx816xx8 ')
    # print(len(a[1]))
    # print(a)
    get_cardNo(cardNo_file_path)

成本展示:

在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值