常用代码参考模板

  • Python
  • 使用multiprocessing模块并发任务
  • Python操作数据库
  • subprocess执行cmd命令
  • Shell
  • 文件存在符&逻辑判断符&运算符
  • 串行
  • 并发
  • 免交互登录
  • 输入数字运行相应命令 case ...when...
  • SQL
  • 账号授权
  • 表操作
  • 常见函数使用---字符函数
  • 常见函数使用---日期函数
  • 常见函数使用---聚合函数



github https://github.com/yangle92/


知识库

Python

使用multiprocessing模块并发任务

from multiprocessing import Pool
import time
def ssh (ip):
    print ("login in %s "%ip)
    print(time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()))
    time.sleep(10)
if __name__ == '__main__':
    with Pool(50) as p:
        p.map(ssh,["192.168.1."+ str(i) for i in range(100)])

Python操作数据库

import pymysql
def Mysql_handle(result):
    # 打开数据库连接
    db = pymysql.Connect(
        host='192.168.1.50',
        port=3306,
        user='root',
        passwd="root",
        db='test',
        charset="utf8"
    )
    # 使用 cursor() 方法创建一个游标对象 cursor
    cursor = db.cursor()
    try:
        # 执行sql语句
        db.commit()
    except Exception as e:
        # 如果发生错误则回滚
        print(e)
        db.rollback()
    finally:
        results = cursor.fetchall()
        print(results)
    # 关闭数据库连接
    db.close()

subprocess执行cmd命令

# -*- coding:UTF-8 -*-
import subprocess
cmd='ifconfig'
p = subprocess.Popen(cmd, stdout=subprocess.PIPE,shell=True)
r1=p.stdout.readlines()
r2=[i.strip().decode('gb2312') for i in r1 if i != b'\r\n' ]
print(r2)

Shell

文件存在符&逻辑判断符&运算符

-e ----判断对象是否存在
-d ----判断对象是否存在,并且为目录
-f ----判断对象是否存在,并且为常规文件
-L ----判断对象是否存在,并且为符号链接
-h ----判断对象是否存在,并且为软链接
-s ----判断对象是否存在,并且长度不为0
-r ----判断对象是否存在,并且可读
-w ----判断对象是否存在,并且可写
-x ----判断对象是否存在,并且可执行
-c file ----    文件为字符特殊文件为真
-b file ----    文件为块特殊文件为真
-t file ----    当文件描述符(默认为1)指定的设备为终端时为真
-O ----判断对象是否存在,并且属于当前用户
-G ----判断对象是否存在,并且属于当前用户组
-nt ----判断file1是否比file2新  [ "/data/file1" -nt "/data/file2" ]
-ot ---- 判断file1是否比file2旧  [ "/data/file1" -ot "/data/file2" ]
[ -x "/bin/ls" ] :判断/bin/ls是否存在并有可执行权限
[ -n "$var" ] :判断$var变量是否有值
[ "$a" = "$b" ] :判断$a和$b是否相等
-ne —比较两个参数是否不相等
-lt —参数1是否小于参数2
-le —参数1是否小于等于参数2
-gt —参数1是否大于参数2
-ge —参数1是否大于等于参数2
-e                          文件存在
-a                          文件存在(已被弃用)
-f                           被测文件是一个regular文件(正常文件,非目录或设备)
-s                          文件长度不为0
-b                          被测对象是块设备
-c                          被测对象是字符设备
-p                          被测对象是管道
-h                          被测文件是符号连接
-L                          被测文件是符号连接
-S(大写)                 被测文件是一个socket
-t                          关联到一个终端设备的文件描述符。用来检测脚本的stdin[-t0]或[-t1]是一个终端
-r                          文件具有读权限,针对运行脚本的用户
-w                         文件具有写权限,针对运行脚本的用户
-x                          文件具有执行权限,针对运行脚本的用户
-u                          set-user-id(suid)标志到文件,即普通用户可以使用的root权限文件,通过chmod +s file实现
-k                          设置粘贴位
-O                         运行脚本的用户是文件的所有者
-G                         文件的group-id和运行脚本的用户相同
-N                         从文件最后被阅读到现在,是否被修改
f1 -nt f2                文件f1是否比f2新
f1 -ot f2                文件f1是否比f2旧
f1 -ef f2                文件f1和f2是否硬连接到同一个文件
二元比较操作符,比较变量或比较数字
整数比较:
-eq                       等于            if [ "$a" -eq "$b" ]
-ne                       不等于          if [ "$a" -ne "$b" ]
-gt                       大于            if [ "$a" -gt "$b" ]
-ge                       大于等于      if [ "$a" -ge "$b" ]
-lt                         小于            if [ "$a" -lt "$b" ]
-le                        小于等于      if [ "$a" -le "$b" ]
<                          小于(需要双括号)       (( "$a" < "$b" ))
<=                        小于等于(...)                (( "$a" <= "$b" ))
>                          大于(...)                      (( "$a" > "$b" ))
>=                        大于等于(...)                (( "$a" >= "$b" ))
字符串比较:
=                          等于           if [ "$a" = "$b" ]
==                        与=等价
!=                         不等于        if [ "$a" = "$b" ]
<                          小于,在ASCII字母中的顺序:
                            if [[ "$a" < "$b" ]]
                            if [ "$a" \< "$b" ]         #需要对<进行转义
>                          大于
-z                         字符串为null,即长度为0
-n                         字符串不为null,即长度不为0
命令的间逻辑关系:
       逻辑与: &&
              第一个条件为假时,第二条件不用再判断,最终结果已经有;
              第一个条件为真时,第二条件必须得判断;
       逻辑或: ||

串行

#!/bin/bash
Njob=15    #任务总数
for ((i=0; i<$Njob; i++)); do
{
          echo  "progress $i is sleeping for 3 seconds zzz…"
          sleep  3
}
done
echo -e "time-consuming: $SECONDS    seconds"    #显示脚本执行耗时

并发

#!/bin/bash
Njob=15    #任务总数
for ((i=0; i<$Njob; i++)); do
{
          echo  "progress $i is sleeping for 3 seconds zzz…"
          sleep  3
} &
done
wait
echo -e "time-consuming: $SECONDS    seconds"    #显示脚本执行耗时

免交互登录

#!/bin/bash
##############################################################
#创建10个用户,并分别设置密码,密码要求10位且包含大小写字母以及数字
#最后需要把每个用户的密码存在指定文件中#前提条件:安装mkpasswd命令
##############################################################
#生成10个用户的序列(00-09)
for u in `seq -w 0 09`
do
 #创建用户
 useradd user_$u
 #生成密码
 p=`mkpasswd -s 0 -l 10` 
 #从标准输入中读取密码进行修改(不安全)
 echo $p|passwd --stdin user_$u
 #常规修改密码
 echo -e "$p\n$p"|passwd user_$u
 #将创建的用户及对应的密码记录到日志文件中
 echo "user_$u $p" >> /tmp/userpassworddone
done

输入数字运行相应命令 case …when…

#!/bin/bash
##############################################################
#输入数字运行相应命令
##############################################################
echo "*cmd menu* 1-date 2-ls 3-who 4-pwd 0-exit "
while :
do
#捕获用户键入值
 read -p "please input number :" n
 n1=`echo $n|sed s'/[0-9]//'g`
#空输入检测 
 if [ -z "$n" ]
 then
 continue
 fi
#非数字输入检测 
 if [ -n "$n1" ]
 then
 exit 0
 fi
 break
done
case $n in
 1)
 date
 ;;
 2)
 ls
 ;;
 3)
 who
 ;;
 4)
 pwd
 ;;
 0)
 break
 ;;
    #输入数字非1-4的提示
 *)
 echo "please input number is [1-4]"
esac

SQL

账号授权

在此界面输入sqlplus /nolog回车
再输入conn /as sysdba回车
select    name    from    v$datafile;  查看数据库文件存放地址,一会指定表空间路径需要,回车后
1、创建表空间
create tablespace table1
    logging
    datafile 'D:\APP\ADMINISTRATOR\ORADATA\ITSM1\table1.dbf'
    size 1000m
    autoextend on
    next 100m maxsize 2048m
    extent management local;


create temporary tablespace table1_temp
   tempfile 'D:\APP\ADMINISTRATOR\ORADATA\ITSM1\table1_temp.dbf'
   size 100m
   autoextend on
   next 100m maxsize 2048m
   extent management local;
   
3、创建用户、并指定表空间
create user dbadmin  identified by dbadmin default tablespace table1 temporary tablespace table1_temp;
  
4、授权、登录、dba权限等
grant connect,resource,dba to dbadmin;
grant unlimited tablespace to dbadmin;

表操作

5、表操作

	/*创建表*/
	  CREATE TABLE table1
	(
	Id_P int,
	LastName varchar(255),
	FirstName varchar(255),
	Address varchar(255),
	City varchar(255)
	)
	 
	/*修改表字段*/
	alter table table1 drop column Id_P
	alter table table1 add Id_P int ;
	
	/*创建序列*/
	create sequence Id_P start with 1 increment by 1;  

	/*增加表内容*/
	INSERT INTO table1 VALUES (value1,value2,value3,...);

	/*制定单元格插入内容*/
	INSERT INTO table1(LastName,FirstName,Address,City) values ('Tony','Ann','America center park','NewYork' );

	INSERT INTO table1(LastName,FirstName,Address,City) values ('Anix','Aoteman','Earth ','Japanese' );

	INSERT INTO table1 values ('Tony','Ann','America center park','NewYork',ID_P.Nextval );

	INSERT INTO table1 values ('Anix','Aoteman','Earth ','Japanese',ID_P.Nextval );
	
	/*删除表内容*/
	delete from table1 where table1.ID_P is null 
		
	/*修改表内容*/
	UPDATE table1 set LastName='Obu' where table1.ID_P=2
	
	/*查询表*/
	select * from table1 where  table1.ID_P=2

常见函数使用—字符函数

--字符函数
select substr('abcdefg',1,5)substr,                     --字符串截取
       instr('abcdefg','bc') instr,                     --查找子串

       'Hello'||'World' concat,                         --连接

       trim('  wish  ') trim,                           --去前后空格
       rtrim('wish  ') rtrim,                           --去后面空格
       ltrim('  wish') ltrim,                           --去前面空格

       trim(leading 'w' from 'wish') deleteprefix,      --去前缀
       trim(trailing 'h' from 'wish') deletetrailing,   --去后缀
       trim('w' from 'wish') trim1,

       ascii('A') A1, 
       ascii('a') A2,                                   --ascii(转换为对应的十进制数)
       chr(65) C1, 
       chr(97) C2,                                      --chr(十进制转对应字符)

       length('abcdefg') len,                           --length 

       lower('WISH')lower, 
       upper('wish')upper, 
       initcap('wish')initcap,                            --大小写变换

       replace('wish1','1','youhappy') replace,           --替换

       translate('wish1','1','y')translate,               --转换,对应一位(前面的位数大于等于后面的位数)
       translate('wish1','sh1','hy')translate1,

       concat('11','22') concat                     --连接


from dual;

常见函数使用—日期函数

--日期
--年 yyyy yyy yy year
--月 month mm mon month
--日+星期  dd ddd(一年中第几天) dy day 
--小时  hh hh24 
--分 mi
--秒 ss

select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss')currenttime, 
       to_char(sysdate,'yyyy') year,
       to_char(sysdate,'mm') month,
       to_char(sysdate,'dd') day,
       to_char(sysdate,'day') week,
       to_char(sysdate,'hh24')hour,
       to_char(sysdate,'mi') minute,
       to_char(sysdate,'ss') second
from dual;

select to_date('2009-07-04 05:02:01','yyyy-mm-dd hh24:mi:ss')currenttime,
       to_char(to_date('2009-07-04 05:02:01','yyyy-mm-dd hh24:mi:ss'),'yyyy')year,
       to_char(to_date('2009-07-04 05:02:01','yyyy-mm-dd hh24:mi:ss'),'mm')month,
       to_char(to_date('2009-07-04 05:02:01','yyyy-mm-dd hh24:mi:ss'),'dd') day,
       to_char(to_date('2009-07-04 05:02:01','yyyy-mm-dd hh24:mi:ss'),'day') week,
       to_char(to_date('2009-07-04 05:02:01','yyyy-mm-dd hh24:mi:ss'),'day','NLS_DATE_LANGUAGE=American') week, --设置语言
       to_char(to_date('2009-07-04 05:02:01','yyyy-mm-dd hh24:mi:ss'),'hh24')hour,
       to_char(to_date('2009-07-04 05:02:01','yyyy-mm-dd hh24:mi:ss'),'mi') minute,
       to_char(to_date('2009-07-04 05:02:01','yyyy-mm-dd hh24:mi:ss'),'ss') second
from dual;

--months_between
 select months_between(to_date('03-31-2014','MM-DD-YYYY'),to_date('12-31-2013','MM-DD-YYYY')) "MONTHS"
 FROM DUAL;

--next_day
select sysdate today, next_day(sysdate,6) nextweek from dual;

--时间区间
select cardid, borrowdate from borrow where to_date(borrowdate,'yyyy-mm-dd hh24:mi:ss')  
between 
to_date('2014-02-01 00:00:00','yyyy-mm-dd hh24:mi:ss') and 
to_date('2014-05-01 00:00:00','yyyy-mm-dd hh24:mi:ss');  

--interval 间隔
select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') currenttime,
       to_char(sysdate - interval '7' year,'yyyy-mm-dd hh24:mi:ss') intervalyear,   
       to_char(sysdate - interval '7' month,'yyyy-mm-dd hh24:mi:ss') intervalMonth,   
       to_char(sysdate - interval '7' day,'yyyy-mm-dd hh24:mi:ss') intervalday,   
       to_char(sysdate - interval '7' hour,'yyyy-mm-dd hh24:mi:ss') intervalHour,   
       to_char(sysdate - interval '7' minute,'yyyy-mm-dd hh24:mi:ss') intervalMinute,   
       to_char(sysdate - interval '7' second,'yyyy-mm-dd hh24:mi:ss') intervalSecond  
from dual;  


--add_months 增加月份
select add_months(sysdate,12) newtime from dual;

--extract
select extract(month from sysdate) "This Month",
extract(year from add_months(sysdate,36)) " Years" from dual;

常见函数使用—聚合函数

--count
select count(1) as count from student;--效率最高
select count(*) as count from student;    
select count(distinct score) from student; 

--avg
--distinct|all
select avg(score) score from student;
select avg(distinct score) from student;
select classno,avg(score) score from student group by classno;

--max
--distinct|all
select max(score) from student;
select classno, max(score) score from student group by classno;

--min
--distinct|all
select min(score) from student;
select classno, min(score) score from student group by classno;

--stddev(standard deviation)标准差
select stddev(score) from student;
select classno, stddev(score) score from student group by classno;

--sum
select sum(score) from student;
select classno, sum(score) score from student group by classno;

--median--中位数
select median(score) from student;
select classno, median(score) score from student group by classno;