技术标签: protobuf go语言 Python docker
Python 是一个动态的解释型强类型的面向对象的编程语言,又叫做胶水语言。太多的不介绍,可以自行百度
学习所有的语言第一个程序都是Hello word。不要问我为什么,仪式感很重要。(用Python3.x写)
print("Hello word")
执行结果如下:
Hello word
以上就是第一个程序了,very easy,作用就是打印Hello word。
关于字符串编码,python2.x默认使用ASCII码,不支持中文,所以如果你使用2.x,就需要声明用utf-8处理你的代码。在文件开头加上下面代码。
# -*- codeing:utf-8 -*-
python3.x默认使用utf-8编码,可以忽略此设置
在Python里单行注释使用#,多行注释使用’’’’’’(三个单引号)或者""""""(三个双引号)
#这是单行注释
print("Hello Word")
'''
这是多行注释
'''
变量是用来存储数据的
python使用等号(=)作为赋值运算符,例如a=20就是一条赋值语句,这条语句用于将20装入a中–>这个过程就是赋值
python用标识符来给变量、函数、类等命名,标识符可以由数字、字母、下划线任意组成,但不能由数字开头,不能是关键字。
a = 123 #变量定义
print(a)
a = "wx" #修改变量值
print(a)
另外,也不建议使用关键字和内置函数名作为变量名,python的关键字如下所示:
>>> keyword.kwlist
['False', 'None', 'True', '__peg_parser__', 'and', 'as', 'assert', 'async', 'await', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield']
内置函数可以参考:https://www.runoob.com/python3/python3-basic-syntax.html
python有六个标准的数据类型:
其中数值、字符串、元组属于不可变数据;列表、集合、字典属于可变数据
python中的数值类型又分为:整数、浮点数和复数
python3支持各种整数值,不管是小整数,还是大整数
#定义变量a,值为整数5
a = 5
print(a)
#修改a的值为一个大整数
a = 9999999999999999999999
print(a)
print(type(a))
#整数也支持None值(空值)
b = None
print(b, type(b))
python的整数值有4种表现形式:
#十进制
n1 = 9
#二进制
n2 = 0b0111
#八进制
n3 = 0o765
#十六进制
n4 = 0x15f
print(n1, n2, n3, n4)
浮点型数值用于保存带小数点的数值,可以使用十进制或者科学计数法表示。需要注意,只有浮点数才能使用科学计数法。
#十进制小数
a = 3.14157
#科学计数法
b = 5e3
print(a, b)
顾名思义,字符串就是一串字符,例如"Hello World"就是一个字符串。在python中,字符串要使用单引号或双引号引起来。
s1, s2 = 'hi', "你好" #同时定义多个变量
print(s1, s2)
如果字符串含有特殊字符,可以使用反斜线()将特殊字符进行转移,例如,字符串本身既包含单引号又包含双引号。
#转义字符
s3 = "I'm a bad boy\"!" #如果不加\会报语法错误
print(s3)
长字符串可以使用三个单引号或三个双引号包括:
#长字符串
long_str = '''
海上生明月,
天涯共此时
'''
print(long_str)
将两个字符串连接起来,可以使用+号:
#使用+拼接字符串
s4 = "Python" + 'is Funny'
print(s4)
由于字符串的反斜线都有特殊作用,如果字符串本身包含反斜线就需要对其进行转义,例如windows路径C:\users\wx,在python中要写成C:\users\wx,这样比较麻烦,可以使用原始字符串解决。
原始字符串以r开头,不会把反斜线当做特殊字符。
#原始字符串,不会让反斜杠发生转义
path = r'C:\User\wx\test'
print(path)
如果字符串中有单引号,这时候还要用反斜杠对单引号进行转义,但是这样会让反斜杠称为单引号的一部分,不符合预期。所以这种情况不建议使用原始字符串。
#如果字符串含有单引号,建议不要使用原始字符串
s5 = r'Let\'s go, said' #打印结果Let\'s go, said
s6 = "Let's go, said"
print(s5, s6)
python提供%占位符对各种类型数据进行格式化数据
name = 'wx'
age = '13'
#%s表示一个占位符,将后面的字符串变量替换到相应位置
print('%s is a %s years old boy' %(name, age))
python支持的占位符如下:
使用上面的占位符时,也可以指定转换后的宽度,对齐方式,浮点数还可以指定精度(小数点后位数):
num= -28
#%6d表示转换后占用6个字符,不足的用空格补齐
print("num is %6d" %(num))
print("num is %6o" %(num))
print("num is %6x" %(num))
print("num is %6s" %(num))
num2 = 13
#最小宽度为6,左对齐
print("num2 is %-6d" %(num2))
#最小宽度为6,不足的用0补齐, 并且数字带正负号
print("num2 is %+06d" %(num2))
#对于浮点数还可以指定小数点后的位数
num3 = 333.1415798753
#最小宽度为5,小数点后保留3位
print("num3 is %5.3f" %(num3))
#最小宽度为8,小数点后保留1位,用0补齐,带正负号
print("num3 is %+08.1f" %(num3))
字符串格式化的另一种方式是使用format函数,使用{}和:来替代之前的%
#按顺序替换,第一个{}对应wang,第二个{}对应13
str1 = "my name is {0}, my age is {1}".format("wang", 13)
print(str1)
#设置指定位置,{0}对应wang,{1}对应13
str2 = "my name is {1}, my age is {0}".format("wang", 13) #my name is 13, my age is wang
print(str2)
#根据名称替换
str3 = "This book name is {name}, price is {price}".format(name="<<老人与海>>", price=24) #This book name is <<老人与海>>, price is 24
print(str3)
format()更多使用方式参考:https://www.runoob.com/python/att-string-format.html
可以通过索引操作字符串,在python中,字符串从左往右第一个索引为0,第二个为1,以此类推;从右往左第一个索引为-1,第二个为-2依次类推。
通过str[index]就可以获取指定索引位的字符
str1 = "www.baidu.com"
#获取索引为2的字符
print(str1[2])
#获取索引为-1的字符
print(str1[-1]
通过索引还可以实现字符串切片,格式是string[start_index:end_index]
str1 = "www.baidu.com"
#获取从索引3到索引8的子字符串,但不包含索引8的
print(str1[3:8])
#获取索引-6到-2的子字符串,不包含索引-2对应的
print(str1[-6:-2])
#省略strart,表示从索引0开始截取
print(str1[:5])
#省略end,表示截取到结尾
print(str1[4:])
#start和end都省略,表示截取整个字符串
print(str1[:])
通过dir(str)可以查看字符串类型所有的属性和方法
>>> dir(str)
['__add__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mod__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmod__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'capitalize', 'casefold', 'center', 'count', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'format_map', 'index', 'isalnum', 'isalpha', 'isascii', 'isdecimal', 'isdigit', 'isidentifier', 'islower', 'isnumeric', 'isprintable', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower', 'lstrip', 'maketrans', 'partition', 'removeprefix', 'removesuffix', 'replace', 'rfind', 'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill']
下面看下常用的一些方法
str1 = "hello World"
#所有单词首字母转为大写,符合title形式
print(str1.title())
#所有字符转为大写
print(str1.upper())
#所有字符转为小写
print(str1.lower())
str2 = " book "
#删除两边空白
print(str2.strip())
#删除左边空白
print(str2.lstrip())
#删除右边空白
print(str2.rstrip())
#指定要删除的字符
print("I think it is easy".rstrip('easy'))
文章浏览阅读1k次。通过使用ajax方法跨域请求是浏览器所不允许的,浏览器出于安全考虑是禁止的。警告信息如下:不过jQuery对跨域问题也有解决方案,使用jsonp的方式解决,方法如下:$.ajax({ async:false, url: 'http://www.mysite.com/demo.do', // 跨域URL ty..._nginx不停的xhr
文章浏览阅读2k次。关于在 Oracle 中配置 extproc 以访问 ST_Geometry,也就是我们所说的 使用空间SQL 的方法,官方文档链接如下。http://desktop.arcgis.com/zh-cn/arcmap/latest/manage-data/gdbs-in-oracle/configure-oracle-extproc.htm其实简单总结一下,主要就分为以下几个步骤。..._extproc
文章浏览阅读1.5w次。linux下没有上面的两个函数,需要使用函数 mbstowcs和wcstombsmbstowcs将多字节编码转换为宽字节编码wcstombs将宽字节编码转换为多字节编码这两个函数,转换过程中受到系统编码类型的影响,需要通过设置来设定转换前和转换后的编码类型。通过函数setlocale进行系统编码的设置。linux下输入命名locale -a查看系统支持的编码_linux c++ gbk->utf8
文章浏览阅读750次。今天准备从生产库向测试库进行数据导入,结果在imp导入的时候遇到“ IMP-00009:导出文件异常结束” 错误,google一下,发现可能有如下原因导致imp的数据太大,没有写buffer和commit两个数据库字符集不同从低版本exp的dmp文件,向高版本imp导出的dmp文件出错传输dmp文件时,文件损坏解决办法:imp时指定..._imp-00009导出文件异常结束
文章浏览阅读143次。当下是一个大数据的时代,各个行业都离不开数据的支持。因此,网络爬虫就应运而生。网络爬虫当下最为火热的是Python,Python开发爬虫相对简单,而且功能库相当完善,力压众多开发语言。本次教程我们爬取前程无忧的招聘信息来分析Python程序员需要掌握那些编程技术。首先在谷歌浏览器打开前程无忧的首页,按F12打开浏览器的开发者工具。浏览器开发者工具是用于捕捉网站的请求信息,通过分析请求信息可以了解请..._初级python程序员能力要求
文章浏览阅读7.6k次,点赞2次,收藏6次。@Service标注的bean,类名:ABDemoService查看源码后发现,原来是经过一个特殊处理:当类的名字是以两个或以上的大写字母开头的话,bean的名字会与类名保持一致public class AnnotationBeanNameGenerator implements BeanNameGenerator { private static final String C..._@service beanname
文章浏览阅读6.9w次,点赞73次,收藏463次。1.前序创建#include<stdio.h>#include<string.h>#include<stdlib.h>#include<malloc.h>#include<iostream>#include<stack>#include<queue>using namespace std;typed_二叉树的建立
文章浏览阅读7.1k次。在Asp.net上使用Excel导出功能,如果文件名出现中文,便会以乱码视之。 解决方法: fileName = HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8);_asp.net utf8 导出中文字符乱码
文章浏览阅读2.1k次,点赞4次,收藏23次。第一次实验 词法分析实验报告设计思想词法分析的主要任务是根据文法的词汇表以及对应约定的编码进行一定的识别,找出文件中所有的合法的单词,并给出一定的信息作为最后的结果,用于后续语法分析程序的使用;本实验针对 PL/0 语言 的文法、词汇表编写一个词法分析程序,对于每个单词根据词汇表输出: (单词种类, 单词的值) 二元对。词汇表:种别编码单词符号助记符0beginb..._对pl/0作以下修改扩充。增加单词
文章浏览阅读773次。我在使用adb.exe时遇到了麻烦.我想使用与bash相同的adb.exe shell提示符,所以我决定更改默认的bash二进制文件(当然二进制文件是交叉编译的,一切都很完美)更改bash二进制文件遵循以下顺序> adb remount> adb push bash / system / bin /> adb shell> cd / system / bin> chm..._adb shell mv 权限
文章浏览阅读6.8k次,点赞12次,收藏125次。1. 单目相机标定引言相机标定已经研究多年,标定的算法可以分为基于摄影测量的标定和自标定。其中,应用最为广泛的还是张正友标定法。这是一种简单灵活、高鲁棒性、低成本的相机标定算法。仅需要一台相机和一块平面标定板构建相机标定系统,在标定过程中,相机拍摄多个角度下(至少两个角度,推荐10~20个角度)的标定板图像(相机和标定板都可以移动),即可对相机的内外参数进行标定。下面介绍张氏标定法(以下也这么称呼)的原理。原理相机模型和单应矩阵相机标定,就是对相机的内外参数进行计算的过程,从而得到物体到图像的投影_相机-投影仪标定
文章浏览阅读2.2k次。文章目录Wayland 架构Wayland 渲染Wayland的 硬件支持简 述: 翻译一篇关于和 wayland 有关的技术文章, 其英文标题为Wayland Architecture .Wayland 架构若是想要更好的理解 Wayland 架构及其与 X (X11 or X Window System) 结构;一种很好的方法是将事件从输入设备就开始跟踪, 查看期间所有的屏幕上出现的变化。这就是我们现在对 X 的理解。 内核是从一个输入设备中获取一个事件,并通过 evdev 输入_wayland