dnspod 批量添加记录
#!/usr/bin/python
#-*- coding: utf-8 -*-
import os,requests,json
import re,xlsxwriter,time
import xlrd
#curl -X POST https://dnsapi.cn/Info.Version -d 'login_token=LOGIN_TOKEN&format=json' #时间
date=time.strftime("%Y-%m-%dT%H-%M-%S", time.localtime())
#文件名
name='域名筛选-{0}.xlsx'.format(date) url='https://dnsapi.cn/Info.Version'
token=''
domail_name='daddymami.net' data={'login_token':'{0}'.format(token),'format':'json'}
r = requests.post(url,data=data)
if r.json()['status']['code'] != '':
print('登录失败,检查网站,token,id')
exit(0)
else:
print('登录成功,正在执行脚本') url='https://dnsapi.cn/Domain.List' data={'login_token':'{0}'.format(token),'format':'json','type':'all'}
r = requests.post(url,data=data)
json_data=r.json() #域名名字和id
id_name=dict()
domain_name_all=json_data['domains']
for i in domain_name_all:
id_name[str(i['name'])]=i['id'] print(id_name['daddymami.net']) url='https://dnsapi.cn/Record.Create' ERROR=dict()
#指定文件位置
execl_file=''
#指定页
table_name=''
bk = xlrd.open_workbook(execl_file)
shxrange = range(bk.nsheets)
try:
table = bk.sheet_by_name(table_name)
except:
print ("no sheet in %s named %s"%(execl_file,table_name)) nrows = table.nrows
num=1 for row in range(1,nrows): host_value = table.cell_value(row,1)
Record_type = table.cell_value(row,2)
line_value = table.cell_value(row,3)
Record_value = table.cell_value(row,4)
MX = table.cell_value(row,5)
if host_value != '':
if MX == '-':
data={'login_token':'{0}'.format(token),'format':'json','domain_id':id_name[domail_name],'sub_domain':host_value,'record_line':line_value,'record_type':Record_type,'value':Record_value}
r = requests.post(url,data=data)
output = open('data%s.json'%date, 'w')
ERROR[row]={"code":int(r.json()['status']['code']),"host":str(host_value)}
output.write(json.dumps(ERROR))
num +=1
else:
data={'login_token':'{0}'.format(token),'format':'json','domain_id':id_name[domail_name],'sub_domain':host_value,'record_line':line_value,'record_type':Record_type,'value':Record_value,'mx':MX}
r = requests.post(url,data=data)
output = open('data%s.json'%date, 'w')
ERROR[row]={"code":int(r.json()['status']['code']),"host":str(host_value)}
output.write(json.dumps(ERROR))
num +=1
output.close( )
添加完成后,在做对比,看哪些没添加成功
#!/usr/bin/python
#-*- coding: utf-8 -*-
import os,requests,json
import re,xlsxwriter,time
import xlrd
#curl -X POST https://dnsapi.cn/Info.Version -d 'login_token=LOGIN_TOKEN&format=json'
#文件名
date=time.strftime("%Y-%m-%dT%H-%M-%S", time.localtime())
name='{0}.xlsx'.format(date) def start_data(): #登录测试
url='https://dnsapi.cn/Info.Version'
token=''
domail_name='daddymami.net' data={'login_token':'{0}'.format(token),'format':'json'}
r = requests.post(url,data=data)
if r.json()['status']['code'] != '':
print('登录失败,检查网站,token,id')
exit(0)
else:
print('登录成功,正在执行脚本') #获取域名ID url='https://dnsapi.cn/Domain.List' data={'login_token':'{0}'.format(token),'format':'json','type':'all'}
r = requests.post(url,data=data)
json_data=r.json() #域名名字和id
id_name=dict()
domain_name_all=json_data['domains']
for i in domain_name_all:
id_name[str(i['name'])]=i['id'] print(id_name['daddymami.net']) #获取域名记录
url='https://dnsapi.cn/Record.List' ERROR=dict() #对比dnspod与文档的记录是否一致 #指定文件位置
execl_file=''
#指定页
table_name='' bk = xlrd.open_workbook(execl_file)
shxrange = range(bk.nsheets)
try:
table = bk.sheet_by_name(table_name)
except:
print ("no sheet in %s named %s"%(execl_file,table_name)) nrows = table.nrows
num=1
domail_data=dict()
dict_num=0
for row in range(1,nrows):
host_value = str(table.cell_value(row,1))
Record_type = str(table.cell_value(row,2))
line_value = str(table.cell_value(row,3))
Record_value = str(table.cell_value(row,4))
MX = str(table.cell_value(row,5))
TTL = str(table.cell_value(row,6)) if host_value != '':
data={'login_token':'{0}'.format(token),'format':'json','domain_id':id_name[domail_name],'keyword':host_value}
r = requests.post(url,data=data)
num +=1
print(host_value,int(r.json()['status']['code']))
if int(r.json()['status']['code']) == 1:
num=0
for ii in r.json()['records']:
#由于len从1计数所以这里循环开始就加1
num+=1
if len(ii) > 0:
if str(ii['status']) == 'enabled' and str(ii['name']) == host_value and str(ii['value']) == Record_value and str(ii['line']) == line_value and str(ii['type']) == Record_type:
break
else:
#如果循环的次数等于或等于json里的数据数量,那么意味着这条记录在dnspod不存在,加入到domail_data做记录
if num >= len(r.json()['records']) :
dict_num+=1
domail_data[dict_num]={'host_value':host_value,'Record_type':Record_type,'line_value':line_value,'Record_value':Record_value,'MX':MX,'TTL':TTL}
num=1 else:
dict_num+=1
domail_data[dict_num]={'host_value':host_value,'Record_type':Record_type,'line_value':line_value,'Record_value':Record_value,'MX':MX,'TTL':TTL} output = open('data%s.json'%date, 'w')
output.write(json.dumps(domail_data))
output.close( )
print('xlsx原始数据%sdata%s.json'%(os.path.abspath(os.curdir)+"\\",date))
#为了避免xlsxwriter出现故障导致又要重新查询一次dnspod,这里直接写入到json文件做存储,然后在取出,后面出现故障可直接修改open文件名
start_data()
output = open('data%s.json'%date)
domail_data = json.load(output) #设置文件名
workbook=xlsxwriter.Workbook(name)
#设置宽度
worksheet=workbook.add_worksheet()
worksheet.set_column('A:A',20)
worksheet.set_column('B:B',22)
worksheet.set_column('C:C',20)
worksheet.set_column('D:D',15)
worksheet.set_column('E:E',15)
worksheet.set_column('F:F',15) #生成报表
title = [u'主机记录',u'记录类型',u'线路类型',u'记录值',u'MX优先','TTL']
worksheet.write_row('A1',title)
num = 2
for i in domail_data.keys():
tmp=[domail_data[i]['host_value'],domail_data[i]['Record_type'],domail_data[i]['line_value'],domail_data[i]['Record_value'],domail_data[i]['MX'],domail_data[i]['TTL']]
worksheet.write_row('A{0}'.format(num),tmp)
num+=1 workbook.close()
#
print('执行完毕,文件路径'+os.path.abspath(os.curdir)+"\\"+name)
dnspod 批量添加记录的更多相关文章
- SqlServer 批量添加记录
declare @i int ) begin INSERT INTO [dbo].[Settlements] ([ID] ,[Count] ,[SettlementDate]) VALUES ( ne ...
- 分布式监控系统Zabbix--完整安装记录-批量添加主机和自动发现端口
一.Zabbix-3.0.3批量添加主机的配置如下: 0)被监控机上要安装zabbix_agent,并配置好zabbix_agentd.conf (如下172.29.8.50是zabbix_serve ...
- 批量添加删除Windows server DNS服务 恶意域名 * A记录 指向 127.0.0.1(2019年6月5日更新)
下载链接:https://pan.baidu.com/s/1OUHyvnIfXYF0PdiT-VRyHw 密码:7gjj 注意!本解决方案在本地的Windows server服务器上把恶意域名指向1 ...
- SqlServer——批量操作(批量添加,删除)
批量添加数据: 一条insert语句批量插入多条记录 常见的insert语句,向数据库中,一条语句只能插入一条数据: insert into persons (id_p, lastname , fir ...
- SQL批量添加主键脚本
--SQL批量添加主键脚本 --操作提示:运行此脚本前请记得备份您要操作的数据库 --实现功能:执行脚本后数据库中的所有数据表都会有一个主键 --添加规则1:主键名称为ID(可自己修改),数据类型为整 ...
- .Net中批量添加数据的几种实现方法比较
在.Net中经常会遇到批量添加数据,如将Excel中的数据导入数据库,直接在DataGridView控件中添加数据再保存到数据库等等. 方法一:一条一条循环添加 通常我们的第一反应是采用for或for ...
- ArcGis Python脚本——批量添加字段
先看如何增加一个字段 函数:arcpy.AddField_management 语法:AddFields_management (in_table, field_description) 参数 说明 ...
- 09 ORM 多表操作,创建表,添加记录
1.数据库表关系 1.一对多 为什么需要,重复字段太多 一对多关系表 Book id title price publish_id 1 python 100 1 2 php 200 2 3 go 10 ...
- ADO.NET- 中批量添加数据的几种实现方法比较
在.Net中经常会遇到批量添加数据,如将Excel中的数据导入数据库,直接在DataGridView控件中添加数据再保存到数据库等等. 方法一:一条一条循环添加 通常我们的第一反应是采用for或for ...
随机推荐
- 前端各种mate积累
<!DOCTYPE html> H5标准声明,使用 HTML5 doctype,不区分大小写 <head lang=”en”> 标准的 lang 属性写法 <meta c ...
- Smail 中的一些点
smali中所有操作都需要经过寄存器, 本地寄存器以v开头, 参数寄存器以p开头, 非static方法中p0是this 没有-object后缀的操作指令表示操作的对象是基本类型 invoke-dire ...
- OpenCV学习笔记(十一) 轮廓操作
在图像中寻找轮廓 首先利用Canny算子检测图像的边缘,再利用Canny算子的输出作为 寻找轮廓函数 findContours 的输入.最后用函数 drawContours 画出轮廓.边界Counto ...
- 剑指Offer - 九度1509 - 树中两个结点的最低公共祖先
剑指Offer - 九度1509 - 树中两个结点的最低公共祖先2014-02-07 01:04 题目描述: 给定一棵树,同时给出树中的两个结点,求它们的最低公共祖先. 输入: 输入可能包含多个测试样 ...
- 风格指南--C++
0.避免多重包含是学编程时基本的要求; 1. 前置声明是为了降低编译依赖,防止修改一个头文件引发多米诺效应; 2. 内联函数的合理使用可提高代码执行效率; 3. ‐inl.h 可提高代码可读性 (一般 ...
- 一道简单的CTFpython沙箱逃逸题目
看了几天的ssti注入然后了解到有python沙箱逃逸 学过ssti注入的话python沙箱逃逸还是很容易理解的. 看一道CTF题目,源码的话我改了改,一开始不能用,直接在py2上运行就好. 题目要求 ...
- 转:npm install 时总是报phantomjs-prebuilt@2.1.14安装失败
该文章转自:http://www.cnblogs.com/alice626/p/6206722.html 在npm install时总是报如下错误, 尝试单独安装:npm install phanto ...
- 【操作系统】关于C语言设计程序退出自动关闭窗口的问题
有些同学在做实验一 命令解释程序的编写的时候,输入quit命令退出程序,窗口并没有关闭,如下图所示需要Press any key to continue(按任意键)之后才关闭. 出现这个结果的原因是在 ...
- Python中的多线程编程,线程安全与锁(一)
1. 多线程编程与线程安全相关重要概念 在我的上篇博文 聊聊Python中的GIL 中,我们熟悉了几个特别重要的概念:GIL,线程,进程, 线程安全,原子操作. 以下是简单回顾,详细介绍请直接看聊聊P ...
- 【bzoj1899】[Zjoi2004]Lunch 午餐 dp
题目描述 上午的训练结束了,THU ACM小组集体去吃午餐,他们一行N人来到了著名的十食堂.这里有两个打饭的窗口,每个窗口同一时刻只能给一个人打饭.由于每个人的口味(以及胃口)不同,所以他们要吃的菜各 ...