博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
pip3换源,grep,sed ,awk 三剑客,通配符,linux运行django项目
阅读量:5093 次
发布时间:2019-06-13

本文共 4735 字,大约阅读时间需要 15 分钟。

创建~/.pip文件夹

[root@Salve1 bin]# mkdir ~/.pip

创建pip.conf文件并添加index-url

[root@Salve1 bin]# vi ~/.pip/pip.conf

[global]
index-url = https://pypi.tuna.tsinghua.edu.cn/simple

 

 

{}生成序列
区分变量和字符串

? 匹配一个字符

[a-z]

!

python test.py 1>2.txt 2>&1

#

 

grep  

grep - '' txt

-n显示行号

-i不区分大小写

-c统计行数

-E扩展

-v 取反

-o筛选符合字符

扩展

{1,3}出现一到三次
+
grep -E '5{1}' 1.txt
egrep '5{1}' 1.txt

 

sed

主要是用来讲数据进行选取、替换、删除、新增的命令,如果不加-i选项是不会更改文件内容的,如果不确定的情况下,尽量不要更改系统中的配置文件。

  • sed [选项] '[动作]' 文件名

选项

  • -n :一般sed命令会把所有数据都输出到屏幕上,如果加上-n 则会把经过sed命令处理过的命令输出到屏幕上。
  • -e: 允许对输入数据应用多条sed命令编辑
  • -i:用sed的修改结果直接修改读取数据的文件,而不是由屏幕输出

动作

  • a:追加,在当前行后添加一行或多行
  • c:行替换,用c后面的字符串替换原数据行
  • i:插入,在当前行插入一行或者多行
  • d:删除,删除指定的行
  • p:打印,输出指定的行  必须与-n连用
  • s:字符串替换,用一个字符串替换另外一个字符串。格式为“行范围s/旧字串/新字串/g"    -e

sed -n '1,3p' 1.txt|sed -e 's/\:/\#/g'

 

 

awk 命令

awk是一种编程语言,用于在linux/unix下对文本和数据进行处理。数据可以来自标准输入(stdin)、一个或多个文件,或其它命令的输出。它支持用户自定义函数和动态正则表达式等先进功能,是linux/unix下的一个强大编程工具。它在命令行中使用,但更多是作为脚本来使用。awk有很多内建的功能,比如数组、函数等,这是它和C语言的相同之处,灵活性是awk最大的优势。

  • -F: 指定输入的分隔符 

awk -F ':' '{print $0}' test.txt 使用awk 命令打印文件的所有内容。

awk -F ':' '{print $1"#"$2"#"$3"#"$4}' test.txt 将文件中以冒号分隔的字符替换成以#分隔。

 

NR 行

NF段

$ 列

awk -F ':' '$1 ~ /oo/' test.txt test.txt 文件中匹配oo 并且打印第一段。

 

 

awk是一个报告生成器,它拥有强大的文本格式化的能力,这就是专业的说法。

你可能不理解所谓的报告生成器中的"报告"是什么,你可以把"报告"理解为"报表"或者"表格",也就是说,我们可以利用awk命令,将一些文本整理成我们想要的样子,比如把一些文本整理成"表"的样子,然后再展示出来,刚才概念中提到的"文本格式化的能力",也就是这个意思,其实这样说可能还是不太容易理解,不用着急,当你看到后面的"示例"时,自然会明白awk所擅长的"文本格式化"能力是什么。

 

awk从放弃到入门(1):awk基础 (通俗易懂,快进来看)

awk是由Alfred Aho 、Peter Weinberger 和 Brian Kernighan这三个人创造的,awk由这个三个人的姓氏的首个字母组成。

awk早期是在unix上实现的,所以,我们现在在linux的所使用的awk其实是gawk,也就是GNU awk,简称为gawk,awk还有一个版本,New awk,简称为nawk,但是linux中最常用的还是gawk。

awk从放弃到入门(1):awk基础 (通俗易懂,快进来看)

awk其实是一门编程语言,它支持条件判断、数组、循环等功能。所以,我们也可以把awk理解成一个脚本语言解释器。

 

grep 、sed、awk被称为linux中的"三剑客"。

我们总结一下这三个"剑客"的特长。

grep 更适合单纯的查找或匹配文本

sed  更适合编辑匹配到的文本

awk  更适合格式化文本,对文本进行较复杂格式处理

 

此处,我们只总结 awk

 

 

awk基础

awk基本语法如下,看不懂没关系,我们会慢慢举例。

awk [options] 'program' file1 , file2 , ```

对于上述语法中的program来说,又可以细分成pattern和action,也就是说,awk的基本语法如下

awk [options] 'Pattern{Action}' file

 

从字面上理解 ,action指的就是动作,awk擅长文本格式化,并且将格式化以后的文本输出,所以awk最常用的动作就是print和printf,因为awk要把格式化完成后的文本输出啊,所以,这两个动作最常用。

 

我们先从最简单用法开始了解awk,我们先不使用[options] ,也不指定pattern,直接使用最简单的action,从而开始认识awk,示例如下

awk从放弃到入门(1):awk基础 (通俗易懂,快进来看)

上图中,我们只是使用awk执行了一个打印的动作,将testd文件中的内容打印了出来。

 

好了,现在,我们来操作一下另一个类似的场景。

awk从放弃到入门(1):awk基础 (通俗易懂,快进来看)

上图中的示例没有使用到options和pattern,上图中的awk '{print $5}',表示输出df的信息的第5列,$5表示将当前行按照分隔符分割后的第5列,不指定分隔符时,默认使用空格作为分隔符,细心的你一定发现了,上述信息用的空格不止有一个,而是有连续多个空格,awk自动将连续的空格理解为一个分割符了,是不是比cut命令要简单很多,这样比较简单的例子,有利于我们开始了解awk。

 

awk是逐行处理的,逐行处理的意思就是说,当awk处理一个文本时,会一行一行进行处理,处理完当前行,再处理下一行,awk默认以"换行符"为标记,识别每一行,也就是说,awk跟我们人类一样,每次遇到"回车换行",就认为是当前行的结束,新的一行的开始,awk会按照用户指定的分割符去分割当前行,如果没有指定分割符,默认使用空格作为分隔符。

awk从放弃到入门(1):awk基础 (通俗易懂,快进来看)

 

 

$0 表示显示整行 ,$NF表示当前行分割后的最后一列($0和$NF均为内置变量)

注意,$NF 和 NF 要表达的意思是不一样的,对于awk来说,$NF表示最后一个字段,NF表示当前行被分隔符切开以后,一共有几个字段。

也就是说,假如一行文本被空格分成了7段,那么NF的值就是7,$NF的值就是$7,  而$7表示当前行的第7个字段,也就是最后一列,那么每行的倒数第二列可以写为$(NF-1)。

 

 

我们也可以一次输出多列,使用逗号隔开要输出的多个列,如下,一次性输出第一列和第二列

awk从放弃到入门(1):awk基础 (通俗易懂,快进来看)

同理,也可以一次性输出多个指定的列,如下图

awk从放弃到入门(1):awk基础 (通俗易懂,快进来看)

我们发现,第一行并没有第5列,所以并没有输出任何文本,而第二行有第五列,所以输出了。

 

 

除了输出文本中的列,我们还能够添加自己的字段,将自己的字段与文件中的列结合起来,如下做法,都是可以的。

awk从放弃到入门(1):awk基础 (通俗易懂,快进来看)

从上述实验中可以看出,awk可以灵活的将我们指定的字符与每一列进行拼接,或者把指定的字符当做一个新列插入到原来的列中,也就是awk格式化文本能力的体现。

 

但是要注意,$1这种内置变量的外侧不能加入双引号,否则$1会被当做文本输出,示例如下

awk从放弃到入门(1):awk基础 (通俗易懂,快进来看)

我们也可以输出整行,比如,如下两种写法都表示输出整行。

awk从放弃到入门(1):awk基础 (通俗易懂,快进来看)

我们说过,awk的语法如下

awk [options] 'Pattern{Action}' file

而且我们说过awk是逐行处理的, 刚才已经说过了最常用的Action:print

现在,我们来认识下一Pattern,也就是我们所说的模式

不过,我们准备先把awk中最特殊的模式展示给大家,以后再介绍普通的模式,因为普通模式需要的篇幅比较长,所以我们先来总结特殊模式。

AWK 包含两种特殊的模式:BEGIN 和 END。

BEGIN 模式指定了处理文本之前需要执行的操作:

END 模式指定了处理完所有行之后所需要执行的操作:

什么意思呢?光说不练不容易理解,我们来看一些小例子,先从BEGIN模式开始,示例如下

awk从放弃到入门(1):awk基础 (通俗易懂,快进来看)

上述写法表示,在开始处理test文件中的文本之前,先执行打印动作,输出的内容为"aaa","bbb".

也就是说,上述示例中,虽然指定了test文件作为输入源,但是在开始处理test文本之前,需要先执行BEGIN模式指定的"打印"操作

既然还没有开始逐行处理test文件中的文本,那么是不是根本就不需要指定test文件呢,我们来试试。

awk从放弃到入门(1):awk基础 (通俗易懂,快进来看)

经过实验发现,还真是,我们并没有给定任何输入来源,awk就直接输出信息了,因为,BEGIN模式表示,在处理指定的文本之前,需要先执行BEGIN模式中指定的动作,而上述示例没有给定任何输入源,但是awk还是会先执行BEGIN模式指定的"打印"动作,打印完成后,发现并没有文本可以处理,于是就只完成了"打印 aaa bbb"的操作。

这个时候,如果我们想要awk先执行BEGIN模式指定的动作,再根据执我们自定义的动作去操作文本,该怎么办呢?示例如下

awk从放弃到入门(1):awk基础 (通俗易懂,快进来看)

上图中,蓝色标注的部分表示BEGIN模式指定的动作,这部分动作需要在处理指定的文本之前执行,所以,上图中先打印出了"aaa bbb",当BEGIN模式对应的动作完成后,在使用后面的动作处理对应的文本,即打印test文件中的第一列与第二列,这样解释应该比较清楚了吧。

看完上述示例,似乎更加容易理解BEGIN模式是什么意思了,BEGIN模式的作用就是,在开始逐行处理文本之前,先执行BEGIN模式所指定的动作。以此类推,END模式的作用就一目了然了,举例如下。

awk从放弃到入门(1):awk基础 (通俗易懂,快进来看)

聪明如你一定明白了,END模式就是在处理完所有的指定的文本之后,需要指定的动作。

那么,我们可以结合BEGIN模式和END模式一起使用。示例如下

awk从放弃到入门(1):awk基础 (通俗易懂,快进来看)

 

 

 

 

1.项目立项 甲方干的

2.需求分析 产生一个需求文档
3.需求审核 面向程序的审核 从开发角度来看是否能够实现
4.任务分配
5.组长创建项目仓库 GIT
6.开始编写代码
7.项目测试 单元测试 整合测试
8.项目发布上线

简单的django项目发布
1.打包项目传到服务器
scp D:\jerry\publishTest.zip root@10.0.0.130:/tmp
2.服务器解压运行
2.1 安装python3
需要换源
sudo yum install https://centos7.iuscommunity.org/ius-release.rpm
yum install python36
2.2 安装pip
yum install python36-pip
2.3 安装django
pip3 install django==1.11.9
2.4 关闭服务器防火墙
systemctl stop firewalld
2.5 sqllite数据库问题
重新安装低版本django
pip3 install django==2.1
3.启动服务
python manager.py runserver 10.0.0.130:8080
注意不能使用127.0.0.1 需要使用真实IP

3.1 后台运行服务 并指定django 运行日志路径

python3 manage.py runserver 10.0.0.130:8080 1>>/tmp/weblog.txt 2>>/tmp/err.txt &

 

转载于:https://www.cnblogs.com/wrqysrt/p/10825754.html

你可能感兴趣的文章
在centos上开关tomcat
查看>>
重启rabbitmq服务
查看>>
无人值守安装linux系统
查看>>
【传道】中国首部淘宝卖家演讲公开课:农业本该如此
查看>>
jQuery应用 代码片段
查看>>
MVC+Servlet+mysql+jsp读取数据库信息
查看>>
黑马程序员——2 注释
查看>>
用OGRE1.74搭建游戏框架(三)--加入人物控制和场景
查看>>
转化课-计算机基础及上网过程
查看>>
android dialog使用自定义布局 设置窗体大小位置
查看>>
ionic2+ 基础
查看>>
互联网模式下我们更加应该“专注”
查看>>
myeclipse集成jdk、tomcat8、maven、svn
查看>>
查询消除重复行
查看>>
Win 10 文件浏览器无法打开
查看>>
[leetcode]Minimum Path Sum
查看>>
内存管理 浅析 内存管理/内存优化技巧
查看>>
【BZOJ 5222】[Lydsy2017省队十连测]怪题
查看>>
Java跟Javac,package与import
查看>>
day-12 python实现简单线性回归和多元线性回归算法
查看>>