2017.07.14 update

做了个界面,不需要使用cmd命令行+文件路径的方式来使用了;

链接如下:

http://www.cnblogs.com/chenyuebai/p/7150382.html

- - - - - - - - - - - - - - - - - - - - - - - - - - - - -原博文- - - - - - - - - - - - - - - - - - - - - - - - - - - - -

周末给妹子做的小工具集;大体框架差不多了,支持执行传入参数,从而指定功能;

再写个readme放桌面上,里面描述命令对应功能,把命令行粘贴到cmd命令台,回车执行即可;     #原始文件路径写死了(放她PC桌面上)

                                               #common_tools.py路径配到环境变量里

如:1.格式化手机号: python common_tools.py 1

  2.XXXXXX功能: python common_tools.py 2

  ...

目前就一个功能:批量格式化手机号,适配她公司短信群发平台

详细涉及:

(1)文件读取  (2)数据格式化  (3)短信群发平台每次仅支持50人,需要适配  (4)支持默认收件人  (5)异常手机号提示  (6)自动将前50拷贝到剪切板【未实现】

另外后续可能加其他功能,需要支持外部参数传入,指定某功能

#20170613更新:自动将执行结果拷贝至剪切板

代码:


################################################################# 
#author: 陈月白
#_blogs: http://www.cnblogs.com/chenyuebai/
################################################################# #coding: utf -8
import sys
import traceback
import pyperclip class COMMON_TOOLS():
def __init__(self):
#原始数据文件
self.data_file = r"C:\Apps\install_zmj\workspace_ch\cfg\data.txt"
#函数表
self.function_map = {
"":"format_msg_receiver"
} #参数转function
def args_trans2function(self,argCode):
if argCode:
try:
function_name = self.function_map[argCode]
#print("INFO:function_name =",function_name)
return function_name
except:
print("ERROR:code:%s no this function,plz connect CHEN...输入函数代码不在此工具的函数列表中,请联系陈"%argCode) #拉起功能函数
def start_execute_function(self,function_name):
if function_2_exe == "format_msg_receiver":
try:
print("now begin to execute:",function_2_exe)
data = open(self.data_file, "r", encoding="UTF-8")
self.format_msg_receiver(data)
except:
traceback.print_exc()
print("ERROR:begin exe format_msg_receiver failed") #格式化短信收件人
def format_msg_receiver(self,receiver_info):
#配置默认收件人
result = "132******96,135******23"
flag = 0
if receiver_info:
try:
for receiver_num in receiver_info.readlines():
#print(receiver_num)
#原始数据格式检查是否为手机号;如果不是11位,且不是空,打出错误信息;空值过滤
if not len(receiver_num.replace("\n","")) == 11:
if not receiver_num.replace("\n","") == "":
print("WARNING:手机号异常--> %s 建议人工修改最后输出结果 或原始文件:data.txt"%(receiver_num.replace("\n","")))
#格式化,空值跳过
if not receiver_num.replace("\n","") == "":
#print("receiver_num =",receiver_num)
result = result + "," + receiver_num.replace("\n","")
flag = flag + 1 print("\nINFO:格式化联系人完成,共格式化联系人 %s 个 提示:最大支持100个"%flag)
if result:
result_list = result.split(",")
#print("result_list =",result_list)
if len(result_list) <= 50:
print("INFO:最终结果如下:\n")
print(result)
#拷贝内容至剪切板
try:
self.copy_2_clipboard(result)
print("\n【结果已自动拷贝至剪切板,直接粘贴即可】\n")
except:
pass
#适配群发短信工具,大于50人处理,支持最大100个联系人
else:
#处理前50个
result_list_50 = result_list[0:50]
result_50_out = ""
flag_50 = 0
#print("result_list_50 =",result_list_50)
for i in result_list_50:
if flag_50 == 0:
result_50_out = result_50_out + i
flag_50 = flag_50 + 1
else:
result_50_out = result_50_out + "," + i
flag_50 = flag_50 + 1
#处理剩余部分
result_list_other = result_list[50:]
flag_other = 0
result_other_out = ""
for i in result_list_other:
if flag_other == 0:
result_other_out = result_other_out + i
flag_other = flag_other + 1
else:
result_other_out = result_other_out + "," + i
flag_other = flag_other + 1
print("INFO:适配群发短信工具,前50个为:\n%s\n"%result_50_out)
#拷贝内容至剪切板
try:
self.copy_2_clipboard(result_50_out)
print("【上述前50个已自动拷贝至剪切板,直接粘贴即可】\n")
except:
pass print("INFO:其他部分为:\n%s\n"%result_other_out)
return 0
except:
traceback.print_exc()
print("ERROR:function format_msg_receiver execute failed!\n 请联系陈") #拷贝str至剪切板
def copy_2_clipboard(self,str_data):
try:
if str_data:
pyperclip.copy(str_data)
#print("INFO:拷贝至剪切板成功")
except:
traceback.print_exc()
#print("ERROR:拷贝至剪切板失败") def main():
global function_2_exe
print("\n--------------------------开始执行--------------------------")
ZMJ = COMMON_TOOLS()
#获取函数
try:
code_input = sys.argv[1]
print("INFO:code_input =",code_input)
function_2_exe = ZMJ.args_trans2function(code_input)
print("INFO:function_2_exe =",function_2_exe)
except:
traceback.print_exc()
print("ERROR:请输出功能参数")
print(r"help info in C:\Apps\install_zmj\workspace_ch\cfg\readme.txt") #执行
if function_2_exe:
ZMJ.start_execute_function(function_2_exe)
else:
print("ERROR:function_2_exe为空,code获取函数名失败") print("--------------------------执行完成--------------------------\n") #入口
main()

执行:

1.原始联系人数据拷贝到指定文件下

2.从readme中拷贝"python common_tools.py 1"至cmd,执行

未完待续。。。

python 3.6 MJ小工具的更多相关文章

  1. python开发目录合并小工具 PathMerge

    前言 这个程序陆陆续续开发了几天,正好我在学Python,就一边做一边学,倒是学到不少东西. 不得不说python是快速开发的好工具. 程序做了一些改进,这两天又忙着毕设,现在才想起来发到博客上.想想 ...

  2. 目不识丁的我使用Python编写汉字注音小工具

    一万点暴击伤害 人懒起来太可怕了,放了个十一充分激发了我的惰性.然后公众号就这么停了半个月,好惭愧- 新学期儿子的幼儿园上线了APP,每天作业通过app布置后,家长需要陪着孩子学习,并上传视频才算完成 ...

  3. python转exe的小工具

    其实只是在cxfreeze的基础上加了个壳,做成窗口软件了 使用了pyqt做的界面,软件发布在了开源中国上,可以直接去下面的地址查看 http://git.oschina.net/robocky/py ...

  4. Python: tkinter实例改名小工具

    #!/usr/bin/env python #coding=utf-8 # # 版权所有 2014 yao_yu (http://blog.csdn.net/yao_yu_126) # 本代码以MIT ...

  5. 入坑python 自己写的小工具,纪念一下

    这个程序的功能是可以从表格中读取某一列数据,传到IDs 这一个参数里,然后在url中获取相应的请求值,并打印 import urllib.request import json import xlrd ...

  6. python一些实用的小工具

    1  搭一个简易的本地局域网  python -m http.server 2 获取当前目录下的所有文件名 3 进度条效果 import sys,time for i in range(50): sy ...

  7. python之字符聊天小工具

    server side: # coding: gb2312#socket server端#获取socket构造及常量from socket import *#''代表服务器为localhostmyHo ...

  8. 几个可以提高工作效率的Python内置小工具

    在这篇文章里,我们将会介绍4个Python解释器自身提供的小工具.这些小工具在笔者的日常工作中经常用到,减少了各种时间的浪费,然而,却很容易被大家忽略.每当有新来的同事看到我这么使用时,都忍不住感叹, ...

  9. 【python】【开源】使用Tkinter和matplotlib实时显示图像,打造属于自己的性能测试小工具

    在腾讯的perfdog工具还未公开时,当时需要查看内存使用情况等信息,就用python写了个小工具 为了提升开发效率,就直接借用了雷子开源的性能测试工具的布局,自己美化了一下,然后加入了实时显示数据的 ...

随机推荐

  1. Count the Colors

    Count the Colors Time Limit:2000MS     Memory Limit:65536KB     64bit IO Format:%lld & %llu Subm ...

  2. SeaJS之shim插件:解决非cmd规范的插件与sea的区别

    SeaJS 中的模块默认都遵守 CMD 规范,但现实中已存在大量普通 JavaScript 类库,比如 jQuery.Underscore 等.使用 shim 插件,可以将这些普通 JS 文件转换成 ...

  3. 使用spring框架中的组件发送邮件

    首先进入自己的QQ邮箱,在设置中修改账户信息 然后来至底部  点击开启,再用手机发送对应信息到指定号码,然后点击我已发送  获取授权码  注意提示: 到这里,相信你已经开通了SMTP服务,这样就可以在 ...

  4. 算法:javascript截取字符串

    题目: Given a string, find the length of the longest substring without repeating characters. Examples: ...

  5. MUI开发记录——我的考勤

    已经好久没有更新技术博客了,因为最近一直在做跨平台web app应用的开发,由于是刚做这个,也没太多经验同大家分享,可我是一个闲不住的人,我还是决定于百忙之中抽空整理一篇,记录下开发历程......— ...

  6. Makefile例子引入

    Makefile规则 target ... :prerequisites... command target就是一个目标文件,可以是object file,也可以是可以执行文件,也可以是一个标签 pr ...

  7. Python字符串之StringIO和struct

    StringIO: 提供类文件接口的字符串缓冲区,可选用性能更好的cStringIO版本: http://docs.python.org/2.7/library/stringio.html#modul ...

  8. 【解决方案】纯js动态克隆表一行元素

    1 m = 0 ;// 用于区分input // 新增一条录入 function AddTR(){ m += 1; var tableObject = document.getElementById( ...

  9. while循环小练习-猜答案

    条件 1.每个用户只能猜10次产品的价格2.每次猜玩价格,提示用户价格是多了还是少了或者对了3.如果用户才对则终止程序执行 break! i = 0 #设置一个次数变量 price = 38 #设置一 ...

  10. android堆栈调试--详细

    1.将ndk中的arm-linux-androideabi-addr2line可执行文件的路径加入配置文件~/.bashrc中,例如: export PATH=$PATH:~/dlna/android ...