python3-基础教程

目录

10 def 函数

11 函数 参数

12 函数默认参数

13 全局 & 局部变量, global & local

14 模块安装

15 读写文件1

16 读写文件2

17 文件读写3

18 class 类

19 类 init 功能

20 input 输入

21 元组 列表

22 列表 list

23 多维列表

24 字典 dictionary

25 import 载入模块

26 自己的模块

27 continue & break

28 错误处理 try

29 zip lambda map

30 浅复制&深复制, copy & deepcopy

1 Python threading 1 什么是多线程

32 Python multiprocessing 1 介绍

33 Python tkinter 1 什么是tkinter窗口

34 pickle 存放数据

35 set 找不同

36 RegEx 正则表达

函数

可以指定参数赋值更加清楚,如果不指定则按顺序赋值

def function(a,b):
    c = a + b
    print("the c is ",c)

function(1,2) #a=1,b=2
function(a=1,b=1)#a=1,b=2
function(b=2,a=1)#a=1,b=2

默认参数值

若如果在形参表当中已经对参数赋值,则在调用时可以不再赋值而函数会自动调用默认值,若在实参中重新赋值则丢弃默认值接受传递值

注意:但是要保证所有未给默认值的参数要在给定默认值参数之前

全局与局部变量

在函数外定义的变量就是全局变量在任何地方无论函数内外都可以被调用,但是你对在函数内部使用函数外部定义的全局变量时,需要如下使用:
a = None
def func():
    global a
    a = 20

首选如果你并不对全局变量做赋值操作时,那么你可以不需要 global语句直接使用,但是一旦要使用赋值语句的时候你就需要是a位于等号左边,这样相当于定义了一个局部变量,而对该变量赋值并不会改变函数的全局变量,因为变量同名就近原则,所以如果此时想用全局变量必须global

在函数内部定义的变量仅能在函数内部被调用

python文件读写

写文件

#打开文件
my_file = open('myfile.txt',"w")
#写入字符串
my_file.write(str)
#关闭文件
my_file.close()
#打开文件
my_file = open('myfile.txt',"a")
#追加写入字符串
my_file.write(appended_str)
#关闭文件
my_file.close()

'myfile.txt’是我们要打开的文件,如果是已经可以找到的文件则将该文件直接返回给my_file,并有后面参数的权限,如果没有对应的文件则会自己新建一个文件并返回给my_file

第二个参数是要以什么形式打开文件,常见参数:
w : 写东西进去,并且每次写入会将以前内容覆盖
r : 以只读形式打开只能查看,并不能写入
a : 写东西进去,并且每次写入会接着以前内容不会覆盖

读文件

#以只读形式打开文件,这里的文件和写的时候不一样一旦没有会报错,一定打开已有文件进行读取
my_file = open('myfile.txt',"r")
#读取文件中所有内容
my_file.read(appended_str)
#读取文件中第一行内容,如果接着使用则读取下一行
my_file.readline(appended_str)
#读取文件中所有行内容,并且把每一行读的内容组织成字符串并作为一个元素,则所有行读取后的内容构成列表作为读取结果
my_file.readline(appended_str)
#关闭文件
my_file.close()

类(class)

基本定义

class Caculator:
    name="good Caculator"
    price =18
    def add(self,x,y):
        print(self.name)
        res = a + b
        print(res)
    def minus(self,x,y):
        res = a - b
        print(res)
    def times(self,x,y):
        res = a * b
        print(res)
    def devide(self,x,y):
        res = a + b
        print(res)

1.类一般包含类属性和类方法

2.类当中的方法分为两种一种是实例方法,一种是静态方法。

1)若如果为实例方法那么则方法的第一个参数就是self,就是对自身类的一个引用。则若如果调用需要实例化对象以后使用"对象.方法名()"调用函数,并且在实例方法中可以通过self.s属性调用类中定义的变量。

2)若无self相当于静态方法可以只直接使用"类名.方法名()"调用函数,然而"对象.方法名()"仍然奏效

类的初始化-init()方法

init方法是是对类中的属性进行初始化或者进行一些操作或者调用该类中的其他方法以及其他类以及内部的属性和方法

init方法适合其他函数一样的类方法,仍然需要保证第一个参数为self并且可以设置默认值

如果我们未定义该方法,那么类中会自动调用默认的构造方法即(无任何操作):

def _init_ (self):

但是一旦定义了init方法,那么原来默认的构造方法就被抛弃,就以新的为构造函数进行初始化,定义类的时候会自动调用该方法,而定义类后面的括号就是构造函数的形参表。

input输入

a_input = input("please input a number:")

作用:将input函数的字符串形式的参数打印在屏幕上,并且接受键盘的输入值组织成字符串的形式并赋值给变量a_input
若如果你要得到特定类型的数据就要适用强制类型转换

a_input = int(input("please input a number:"))

元组(tuple) and 列表(list)

都是由一连串有序的元素构成

定义方法:

tuple:使用()定义或者直接定义

a_tuple = (12,23,46,78)
a_tuple = 12,23,46,78

list:使用[]定义

a_list = [12,23,46,78]

使用方法

循环依次处理元素:

for number in a_tuple:
    print(number)

for number in a_list:
    print(number)
    

循环依次按位取值:

for index in range(len(a_tuple)):
    print(number)


for index in range(len(a_list)):
    print(number)

1.len()函数作用是计算列表或者元组中元素的个数
2.range(n)是产生一个迭代器列表,从0迭代到n-1

列表专题

1.在最后追加元素:

a_list = [12,23,46,78]
a_list.append(0) #在列表最后追加元素0

2.指定位置插入元素:

a_list = [12,23,46,78]
a_list.insert(1,0) #在列表中序号为1的位置插入元素0

3.获得值对应元素索引:

a_list = [12,23,46,78]
a_list.insert(2) #获得列表当中第一次出现的2的索引

3.获得值对应元素索引:

a_list = [2,12,2,23,46,78]
a_list.count(2) #获得列表当中第一次出现的2的索引

4.统计出现次数指定值:

a_list = [2,12,2,23,46,78]
a_list.count(2) #输出列表中出现2的次数

5.删除最后一个值:

a_list = [12,23,46,78]
a_list.pop() #删除列表中最后一个值78

6.排序:

a_list = [12,23,46,78]
a_list.sort() #将列表从小到大排序并覆盖原有list
a_list.sort(reverse=True) #将列表从大到小排序并覆盖原有list

7.切片:

python列表从左至有从0为起始,从右至左移-1起始
:是从哪到哪的意思,如果一端空缺为无穷,左为负无穷,右为正无穷,且左右两端取值左闭右开

a_list = [12,23,46,78]
print(a_list[0:2])
print(a_list[:2])
print(a_list[1:])
print(a_list[:])

字典-dictionary

无序的元素构成的列表,且每一个元素都是一个键值对,其实就是一个改变索引值的列表,原来列表的索引值是确定的数字,现在可以是任意数字和字符串作为索引也就是冒号左端的东西成为键,而键对应存储的值仍叫值,值可以是任意类型的数、字符串、以及元组和列表甚至字典和函数

def function():
    return 29
a_dict = {'apple':[1,2,3],"pear":{'a':2,'b':3},"bnana":function()}
print(a_dict['pear']['a'])

运行结果:
2

定义方法

a_list = [1,2,3,4,5]
a_dict = {'apple':1,"pear":2,"bnana":3}

使用方法

1.使用键可以调用对用值

print(a_dict['apple'])

2.使用键可以删除对用值

del a_dict['apple']
print(a_dict)

3.在字典中插入一个元素

a_dict['orange'] = 20 #插入一个键值对 'orange':20
print(a_dict)

import官方模块的方式

1.import time

使用模块名.方法名/属性名调用

import time
print(time.localtime())#输出当前时间
print(time.time())#输出当前时刻是多少秒

2.import time as t

为模块起别名t,如果模块名过于长我们可以用t来代替去引用方法和属性

3.from time import time,localtime #引入多个逗号隔开

引入模块当中特定方法和属性,使用该模块内方法和属性不需要使用模块名调用,直接写函数名和属性名即可

import time
print(localtime())#输出当前时间
print(time())#输出当前时刻是多少秒

4.from time import * #引入多个逗号隔开

引入模块当中所有方法和属性,使用该模块内方法和属性不需要使用模块名调用,直接写函数名和属性名即可

import time
print(localtime())#输出当前时间
print(time())#输出当前时刻是多少秒

引入自己的模块

每一个脚本都可以叫做一个模块,我们调用的方式和引用官方的模块一样,直接把待引用的那块脚本(.py文件)也就是模块的文件名作为模块名之后和前面引用官方模块的方法和属性一样

但是需要注意的是如果直接使用文件名作为模块名导入需要保证导入和待导入脚本在同一个文件夹下,若如果不在两种解决方式

第一写出待导入文件相对于导入文件的路径之间用.连接上下关系

直接将要调用的文件放在和官方库下载在本地的文件夹下

循环中的continue与break

continue:跳过本轮循环

break:跳过当前循环

错误处理-try

try可以针对系统爆出来的错进行处理

注:暂时无read.txt文件时

file = open("read.txt",'r')

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZjjNCkKu-1612539503364)(F5194E4F71284F209C3A34FE1C3C095B)]

发现异常并打印

try:#尝试运行缩进代码块
    file = open("read.txt",'r')
except Exception as e:  #捕获所有Exception类型异常存储到e当中
    print(e)    #缩进部分为捕获异常后对异常的操作这里是打印异常

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-G4BFfsw5-1612539503366)(F99A85E63A5F491D8F80C28B0EA5E63C)]

更多的操作

try:#尝试运行缩进代码块
    file = open("read.txt",'r+')
except Exception as e:  #捕获所有Exception类型异常存储到e当中

#如果没有文件会产生保存并该告诉你"there is no file named as read"并同时询问你"do you want to create a new file(y/n)"如果是y我们就创建一个改名字的文件,其他情况下什么都不做

    print("there is no file named as read")
    repond = input("do you want to create a new file(y/n)")
    if repond=='y':
        file = open("read.txt",'w')
    else:
        pass
        
#如果由该文件,则执行else缩进的代码块写入内容后并关闭
else:
    file.write("yyyyy")
    file.close()

上面的try和else模块是对立事件,如果try下缩进的代码块没有报错则执行后面的else,如果报错则实行except Exception as e:下缩进的对于异常处理的操作

map、zip、lambda

zip

将列表合并起来,是竖向的合并,zip是英文拉链的意思,我们两个列表相当于两个链条,经过拉锁以后链条两端的齿轮是一一对应起来的,这里也是一样将两个列表中对应位置元素组织成元组,但是并不只是可以将两个列表合并对于多个列表也可以,都是将对应位置元素合并成一个n元组,知道所有元素结束。

但是进过zip函数得到的是zip对象,若想可视化则需要将其转化为list()对象

a = [1,2,3]
b = [4,5,6]
zip(a,b)

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ko2k5ZuK-1612539503367)(F468219928DF4320833AE0CBECA5EE71)]

list(zip(a,b))

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-raG64OS1-1612539503369)(8091B615EA604A0889F871DCD5B06FC8)]

可以zip多个列表

list(zip(a,a,b))

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-v8G1m7pD-1612539503371)(DFD76848EBC34E93B7B87E15C883A46B)]

zip对象相当于一个迭代器的输出

for i,j in zip(a,b):
    print(i/2,j*2)

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-zfFuIehy-1612539503372)(A8550ACA3E1C471695B23BCD68498243)]

lambda

lambda和def的作用是一样的都是来定义一个函数,但是lambda通常用作定义代码较少的函数,而且使用lambda定义是后面不需要接函数名函数名放在等号左边二会直接接参数,所以又称匿名函数

def func1(x,y):
    return x+y
func1(2,3)

func2 = lambda x,y:x+y
func2(2,3)

运行结果:
5
5

map

map就是将参数列表和函数连接起来的运算,并运行后将结果组织成列表

map(func1,[1],[2])
#将列表[1]和[2]中的参数依次分别赋给func1中的参数x,y并计算结果
#如果func1有n个非默认参数需要将n个列表并且按顺序列表和func1参数依次连接,
依次将每个列表相同位的数值依次赋给函数求值,并将该值作为相同位置的结果在结果列表中

运行结果:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-7PvVcVux-1612539503372)(3523281AD1744E5FBFF75137401350CA)]
输出的是map的对象,若如果想输出成列表形式,需要如下:

list(map(func1,[1],[2]))

运行结果:
[3]

输入更长的参数列表
list(map(func1,[1,3],[2,4]))
#首先将1,2依次赋给func1参数x,y并计算结果的3
#接着将3,4依次赋给func1参数x,y并计算结果为7
#相当于现将两个列表zip起来形成多个n元组,并将多个n元组依次赋给参数列表并计算结果

赋值复制 and 浅复制 and 深复制 (copy and deepcopy)

(赋值)伪复制

将一个列表赋值给另一个变量实现复制

a = [1,2,3]
b = a

将一个值赋给另一个列表,实现复制,[1,2,3]是在内存中开辟了一段内存地址并存储1,2,3,而a实际是对该块内存的引用即为该段内存起的别名,同样b也是对该块内存的引用即为该段内存起的别名,所以a和b都是对该块内存的引用控制的都是该块内存,所以无论通过a和b那个名字操控该块内存,都是同时对a和b产生影响,只是起了一个别的名字b,并没有真正开辟一段新空间去存储相同内容实现复制,所以有:

print(id(a)==id(b))

运行结果:
True

a和b对应内存同一个位置,实际上是一个东西改变任意一个都影响另一个

浅复制

import copy
a = [1,2,3]
c = copy.copy(a)
print(id(a)==id(c)

运行结果:
Flase

证明c和a变量对应内存当中并不是一个位置,不是一个东西,并且改变a或c中的任何一个元素并不会互相影响

import copy
a = [1,2,[3,4]]
c = copy.copy(a)
print(id(a)==id(c)
print(id(a[2])==id(c[2])
a[0]=11
print(c)
a[2][0]= 333
print(c)

运行结果:
False

True

[1,2,[3,4]]

[1,2,[333,4]]

我们从上面可以看出列表中的元素改变一个并不影响另一个,说明列表中的元素是重新开辟一段空间去存储类表中的元素,而对于列表中的对象元素就是列表,字典,元组等对象改变其中一个元素同时相互影响,因为对象存储的是地址并非存储值,所以当赋值的时候,浅拷贝只拷贝父对象,而不会拷贝子对象,子对象是共用的

深复制

而深度复制是完全复制所有的父对象和子对象,是实现一种id完全不同的一种复制,是开辟一块完全新的的空间并且将值复制一份存到新的空间当中

import copy
a = [1,2,[3,4]]
d = copy.deepcopy(a)
print(id(a)==id(d)
print(id(a[2])==id(d[2])

运行结果:
False

False

pickle 存放数据

保存python运算结果到本地目录上,并且将运算结果进一步其他的加工,我们将就需要包运算结果保存成pickle文件并随时提取进行加工,pickle可以保存列表、字典和变量等一些数据

保存pickle文件

import pickle
a_dict={'da':111,2:[23,1,4],'23':{1:2,'d':'sad'}}
#以二进制写入的方式打开文件pickle
file = open("pickle_example.pickle","wb")
#pickle.dump相当于挖土车,装载的是a_dict并倒入file当中
pickle.dump(a_dict,file)
#关闭文件
file.close()

打开pickle文件继续处理

import pickle
#以二进制读入的方式打开文件pickle
file = open("pickle_example.pickle","rb")
#使用pickle模块来读取file中能够读取的内容并存到另外一个字典当中
a_dict1 = pickle.load(file)
#关闭文件
file.close()
#打印读取内容
print(a_dict1)

可以使用下面代码代替上面代码,使用with可以自动关闭文件,防止忘记

同样写入的时候也可以使用with语句

import pickle
with open("pickle_example.pickle","rb") as file:
    a_dict1 = pickle.load(file)

print(a_dict1)

set

在列表或序列当中找到不同的地方,不重合的地方
char_list[‘a’,‘b’,‘c’,‘c’,‘d’,‘d’,‘d’]
比如上面这个列表当中有一个a和b、2个c、3个d找不同的就是将所有重复的东西剔除掉,只留下不同的地方

基本用法

print(set(char_list))
print(type(set(char_list)))

运行结果:

{‘a’,‘b’,‘c’,‘d’}

输出的结果是类似于字典的形式,以大括号形式表示,但是没有键对形式,是集合(set)形式,但是他返回的形式和字典一样是无序的,破坏了列表的有序性

我们可以将字符串想象成字符列表类似于上面的char_list,使用set会将字符串中以字符为元素进行出去冗余,而且会区分大小写因为大小写在内存中位置不同,而且会保留空格,因为空格也是一个字符

sentence = 'Welcome Back to This Tutorial'
print(set(sentence))

运行结果:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GilEcLlO-1612539503373)(DFB353C5CD4E438D96E94EBB517B0469)]

set当中不可以传入列表的列表,只能传入列表或者元组

char_list['a','b','c','c','d','d','d']
sentence = 'Welcome Back to This Tutorial'
print(set(sentence+char_list))

运算结果:报错

set的功能

向set中添加元素

char_list['a','b','c','c','d','d','d']
unique_list = set(char_list)
unique_list.add('a')
print(unique_list)
unique_list.add('x')
print(unique_list)

运行结果:

{‘d’,‘b’,‘c’,‘a’}

{‘d’,‘x’,‘b’,‘c’,‘a’}

结果分析当我们获得一个set类型的数据当我们想里边添加元素的时候会保持互异性如果里边已经有我们要添加的元素了,我们就可以不用添加了,若没有则需要添加

但是不可以添加一组数(列表)形式,只能单独加,即:

unique_list.add(['x','a'])

运行结果:报错

清空set

char_list['a','b','c','c','d','d','d']
unique_list = set(char_list)
unique_list.clear()
print(unique_list)

运行结果:
set() #空的set

在set中删除元素

char_list['a','b','c','c','d','d','d']
unique_list = set(char_list)
unique_list.add('x')
print(unique_list.remove('x'))
print(unique_list)

运行结果:

None

{‘d’,‘b’,‘c’,‘a’}

unique_list.remove(‘x’)做的是去除集合中的元素’x’,但是返回值是None,若想看去除元素之后的列表需要重新打印一遍,但是除去的元素一定是set中具有的元素,若移除不具有的元素会产生报错,若想避免该种情况可以使用discard函数,它对该种情况不会报错,但是不会减少任何元素

char_list['a','b','c','c','d','d','d']
unique_list = set(char_list)
unique_list.add('x')
print(unique_list.discard('y'))
print(unique_list)

运行结果:

None

{‘d’,’x’,‘b’,‘c’,‘a’}

求集合的交集

set1={'d','x','b','c','a'}
set2={'a','e','i'}
print(set1.intersection(set2))

运行结果:{‘a’}

求集合的差集

求set1具有的元素而set2不具有的元素组成的集合

set1={'d','x','b','c','a'}
set2={'a','e','i'}
print(set1.difference(set2))

运行结果:

{‘d’,’x’,‘b’,‘c’}

正则表达式(Regular Expression)

正则表达式匹配的东西就是在从含有许多固定格式的代码当中,比如网页代码找到我们所需要的信息

正则表达式 (Regular Expression) 又称 RegEx, 是用来匹配字符的一种工具. 在一大串字符中寻找你需要的内容. 它常被用在很多方面, 比如网页爬虫, 文稿整理, 数据筛选等等. 最简单的一个例子, 比如我需要爬取网页中每一页的标题. 而网页中的标题常常是这种形式.

我是标题<title>
</code></pre> 
  <blockquote> 
   <p>而且每个网页的标题各不相同, 我就能使用正则表达式, 用一种简单的匹配方法,通过找两个之间夹的, 一次性选取出成千上万网页的标题信息. 正则表达式绝对不是一天就能学会和记住的, 因为表达式里面的内容非常多, 强烈建议, 现在这个阶段, 你只需要了解正则里都有些什么, 不用记住, 等到你真正需要用到它的时候, 再反过头来, 好好琢磨琢磨, 那个时候才是你需要训练自己记住这些表达式的时候.</p> 
  </blockquote> 
  <h2>简单的匹配</h2> 
  <blockquote> 
   <p>正则表达式无非就是在做这么一回事. 在文字中找到特定的内容, 比如下面的内容. 我们在 dog runs to cat 这句话中寻找是否存在 cat 或者 bird.</p> 
  </blockquote> 
  <pre><code># matching string
pattern1 = "cat"
pattern2 = "bird"
string = "dog runs to cat"
print(pattern1 in string)    # True
print(pattern2 in string)    # False
</code></pre> 
  <blockquote> 
   <p>但是正则表达式绝非不止这样简单的匹配, 它还能做更加高级的内容. 首先需要调用一个 python 的内置模块 re. 然后我们重复上面的步骤, 不过这次使用正则. 可以看出, 如果 re.search() 找到了结果, 它会返回一个 match 的 object. 如果没有匹配到, 它会返回 None. 这个 re.search() 只是 re 中的一个功能, 之后会介绍其它的功能.</p> 
  </blockquote> 
  <pre><code>import re
# regular expression
pattern1 = "cat"
pattern2 = "bird"
string = "dog runs to cat"
print(re.search(pattern1, string)) # <_sre.SRE_Match object; span=(12, 15), match='cat'> 
#就是返回一个对象告诉你我在索引12到15的位置处找到了匹配的cat
print(re.search(pattern2, string)) # None
</code></pre> 
  <h2>灵活匹配</h2> 
  <blockquote> 
   <p>除了上面的简单匹配, 下面的内容才是正则的核心内容, 使用特殊的 pattern 来灵活匹配需要找的文字.</p> 
  </blockquote> 
  <h3>匹配多种可能</h3> 
  <blockquote> 
   <p>如果需要找到潜在的多个可能性文字, 我们可以使用 [] 将可能的字符囊括进来. 比如 [ab] 就说明我想要找的字符可以是 a 也可以是 b. 这里我们还需要注意的是, 建立一个正则的规则, 我们在 pattern 的"“前面需要加上一个 r 用来表示这是正则表达式, 而不是普通字符串. 通过下面这种形式, 如果字符串中出现run或者是ran”, 它都能找到.</p> 
  </blockquote> 
  <pre><code># multiple patterns ("run" or "ran")
ptn = r"r[au]n"       # start with "r" means raw string
print(re.search(ptn, "dog runs to cat"))    # <_sre.SRE_Match object; span=(4, 7), match='run'>
</code></pre> 
  <h3>匹配更多种可能</h3> 
  <blockquote> 
   <p>同样, 中括号 [] 中还可以是以下这些或者是这些的组合. 比如 [A-Z] 表示的就是所有大写的英文字母. [0-9a-z] 表示可以是数字也可以是任何小写字母.</p> 
  </blockquote> 
  <pre><code>print(re.search(r"r[A-Z]n", "dog runs to cat"))     # None
print(re.search(r"r[a-z]n", "dog runs to cat"))     # <_sre.SRE_Match object; span=(4, 7), match='run'>
print(re.search(r"r[0-9]n", "dog r2ns to cat"))     # <_sre.SRE_Match object; span=(4, 7), match='r2n'>
print(re.search(r"r[0-9a-z]n", "dog runs to cat"))  # <_sre.SRE_Match object; span=(4, 7), match='run'>
</code></pre> 
  <h2>按类型匹配</h2> 
  <p>除了上面自己定义规则, 还有很多匹配的规则时提前就给你定义好了的. 下面有一些特殊的匹配类型给大家先总结一下, 然后再上一些例子.</p> 
  <blockquote></blockquote> 
  <p>\d : 任何数字<br> \D : 不是数字<br> \s : 任何 white space, 如 [\t\n\r\f\v]<br> \S : 不是 white space<br> \w : 任何大小写字母, 数字和 _ [a-zA-Z0-9_]<br> \W : 不是 \w<br> \b : 空白字符 (只在某个字的开头或结尾,贴着文字的空白符是可以匹配的到的)<br> \B : 空白字符 (不在某个字的开头或结尾,无论前后是否有空白格子都可以匹配的到)<br> \ : 匹配 <br> . : 匹配任何字符 (除了 \n)<br> ^ : 匹配开头(文字在开头才可以匹配的到)<br> $ : 匹配结尾(文字在结尾才可以匹配的到)<br> ? : 前面的字符可有可无(括号里的内容是否添加的两种情况都匹配)</p> 
  <p>下面就是具体的举例说明啦.</p> 
  <pre><code># \d : decimal digit
print(re.search(r"r\dn", "run r4n"))           # <_sre.SRE_Match object; span=(4, 7), match='r4n'>
# \D : any non-decimal digit
print(re.search(r"r\Dn", "run r4n"))           # <_sre.SRE_Match object; span=(0, 3), match='run'>
# \s : any white space [\t\n\r\f\v]
print(re.search(r"r\sn", "r\nn r4n"))          # <_sre.SRE_Match object; span=(0, 3), match='r\nn'>
# \S : opposite to \s, any non-white space
print(re.search(r"r\Sn", "r\nn r4n"))          # <_sre.SRE_Match object; span=(4, 7), match='r4n'>
# \w : [a-zA-Z0-9_]
print(re.search(r"r\wn", "r\nn r4n"))          # <_sre.SRE_Match object; span=(4, 7), match='r4n'>
# \W : opposite to \w
print(re.search(r"r\Wn", "r\nn r4n"))          # <_sre.SRE_Match object; span=(0, 3), match='r\nn'>
# \b : empty string (only at the start or end of the word)
print(re.search(r"\bruns\b", "dog runs to cat"))    # <_sre.SRE_Match object; span=(4, 8), match='runs'>
# \B : empty string (but not at the start or end of a word)
print(re.search(r"\B runs \B", "dog   runs  to cat"))  # <_sre.SRE_Match object; span=(8, 14), match=' runs '>
# \\ : match \
print(re.search(r"runs\\", "runs\ to me"))     # <_sre.SRE_Match object; span=(0, 5), match='runs\\'>
# . : match anything (except \n)
print(re.search(r"r.n", "r[ns to me"))         # <_sre.SRE_Match object; span=(0, 3), match='r[n'>
# ^ : match line beginning
print(re.search(r"^dog", "dog runs to cat"))   # <_sre.SRE_Match object; span=(0, 3), match='dog'>
# $ : match line ending
print(re.search(r"cat$", "dog runs to cat"))   # <_sre.SRE_Match object; span=(12, 15), match='cat'>
# ? : may or may not occur
print(re.search(r"Mon(day)?", "Monday"))       # <_sre.SRE_Match object; span=(0, 6), match='Monday'>
print(re.search(r"Mon(day)?", "Mon"))          # <_sre.SRE_Match object; span=(0, 3), match='Mon'>
</code></pre> 
  <h2>多行匹配</h2> 
  <blockquote> 
   <p>如果一个字符串有很多行, 上面我们想使用 ^ 形式来匹配行开头的字符, 如果用通常的形式是不成功的. 比如下面的 I 出现在第二行开头, 但是使用 r"^I" 却匹配不到第二行, 这时候, 我们要使用 另外一个参数, 让 re.search() 可以对每一行单独处理. 就是把字符串里的每一个句子都作为单独的句子都具有句尾句首,并依次句首匹配,这个参数就是 flags=re.M, 或者这样写也行 flags=re.MULTILINE.</p> 
  </blockquote> 
  <pre><code>string = """
dog runs to cat.
I run to dog.
"""
print(re.search(r"^I", string))                 # None
print(re.search(r"^I", string, flags=re.M))     # <_sre.SRE_Match object; span=(18, 19), match='I'>
</code></pre> 
  <h2>重复匹配</h2> 
  <p>如果我们想让某个规律被重复使用, 在正则里面也是可以实现的, 而且实现的方式还有很多. 具体可以分为这三种:</p> 
  <blockquote> 
   <ul> 
    <li>: 重复零次或多次(a后面的b出现0次或任意词都是可以匹配的)</li> 
   </ul> 
  </blockquote> 
  <ul> 
   <li>: 重复一次或多次(a后面的b出现一次以上的任意词都是可以匹配的)<br> {n, m} : 重复 n 至 m 次(a后面的b出现n到m次的任意词都是可以匹配的)<br> {n} : 重复 n 次(a后面的b出现n次的词都是可以匹配的)</li> 
  </ul> 
  <p>举例如下:</p> 
  <pre><code># * : occur 0 or more times
print(re.search(r"ab*", "a"))             # <_sre.SRE_Match object; span=(0, 1), match='a'>
print(re.search(r"ab*", "abbbbb"))        # <_sre.SRE_Match object; span=(0, 6), match='abbbbb'>

# + : occur 1 or more times
print(re.search(r"ab+", "a"))             # None
print(re.search(r"ab+", "abbbbb"))        # <_sre.SRE_Match object; span=(0, 6), match='abbbbb'>

# {n, m} : occur n to m times
print(re.search(r"ab{2,10}", "a"))        # None
print(re.search(r"ab{2,10}", "abbbbb"))   # <_sre.SRE_Match object; span=(0, 6), match='abbbbb'>
</code></pre> 
  <h2>分组</h2> 
  <blockquote> 
   <p>我们甚至可以为找到的内容分组, 使用 () 能轻松实现这件事. 通过分组, 我们能轻松定位所找到的内容. 比如在这个 (\d+) 组里, \d是数字有了加号是识别无限长度的数字,需要找到的是一些数字, .是识别出来’\n’以外的所有字符,这样字符构成的无线长度的东西,在 (.+) 这个组里, 我们会找到 Date: 后面的所有内容. 当使用 match.group() 时, 他会返回所有组里的内容, 而如果给 .group(2) 里加一个数, 它就能定位你需要返回哪个组里的信息.</p> 
  </blockquote> 
  <pre><code>match = re.search(r"(\d+), Date: (.+)", "ID: 021523, Date: Feb/12/2017")
#若未指定,则将所有匹配内容完全返回
print(match.group())                   # 021523, Date: Feb/12/2017
#指定后,则将第一个括号内所有匹配内容完全返回
print(match.group(1))                  # 021523
#指定后,则将第二个括号内所有匹配内容完全返回
print(match.group(2))                  # Date: Feb/12/2017
</code></pre> 
  <blockquote> 
   <p>有时候, 组会很多, 光用数字可能比较难找到自己想要的组, 这时候, 如果有一个名字当做索引, 会是一件很容易的事. 我们需要在括号的开头写上这样的形式 ?P<名字> 就给这个组定义了一个名字. 然后就能用这个名字找到这个组的内容.</p> 
  </blockquote> 
  <pre><code>match = re.search(r"(?P<id>\d+), Date: (?P<date>.+)", "ID: 021523, Date: Feb/12/2017")
print(match.group('id'))                # 021523
print(match.group('date'))              # Date: Feb/12/2017
</code></pre> 
  <h2>findall</h2> 
  <blockquote> 
   <p>前面我们说的都是只找到了最开始匹配上的一项而已, 如果需要找到全部的匹配项, 我们可以使用 findall 功能. 然后返回一个列表. 注意下面还有一个新的知识点, | 是 or 的意思, 要不是前者要不是后者.</p> 
  </blockquote> 
  <pre><code># findall
print(re.findall(r"r[ua]n", "run ran ren"))    # ['run', 'ran']

# | : or
print(re.findall(r"(run|ran)", "run ran ren")) # ['run', 'ran']
</code></pre> 
  <h2>replace</h2> 
  <blockquote> 
   <p>我们还能通过正则表达式匹配上一些形式的字符串然后再替代掉这些字符串. 使用这种匹配 re.sub(), 将会比 python 自带的 string.replace() 要灵活多变.</p> 
  </blockquote> 
  <pre><code>print(re.sub(r"r[au]ns", "catches", "dog runs to cat"))     # dog catches to cat
</code></pre> 
  <h2>split</h2> 
  <blockquote> 
   <p>再来我们 Python 中有个字符串的分割功能, 比如想获取一句话中所有的单词. 比如 “a is b”.split(" "), 这样它就会产生一个列表来保存所有单词. 但是在正则中, 这种普通的分割也可以做的淋漓精致.</p> 
  </blockquote> 
  <pre><code>#当遇到,;.其中任一个一个字符的时候就分裂,由于.具有匹配所有除'\n'以外字符,而想真正匹配.则需要加反斜杠
print(re.split(r"[,;\.]", "a;b,c.d;e"))             # ['a', 'b', 'c', 'd', 'e']
</code></pre> 
  <h2>compile</h2> 
  <blockquote> 
   <p>最后, 我们还能使用 compile 过后的正则, 来对这个正则重复使用. 先将正则 compile 进一个变量, 比如 compiled_re, 然后直接使用这个 compiled_re 来搜索.</p> 
  </blockquote> 
  <pre><code>#先将匹配形式给编译起来
compiled_re = re.compile(r"r[ua]n")
#再使用编译器去匹配字符串中的模式
print(compiled_re.search("dog ran to cat"))  # <_sre.SRE_Match object; span=(4, 7), match='ran'>
</code></pre> 
  <h2>小抄</h2> 
  <p>为了大家方便记忆, 我很久以前在网上找到了一份小抄, 这个小抄的原出处应该是这里. 小抄很有用, 不记得的时候回头方便看.</p> 
  <p><a href="http://img.e-com-net.com/image/info8/a05289f7ba9c42f6b55eab4e60195413.jpg" target="_blank"><img src="http://img.e-com-net.com/image/info8/a05289f7ba9c42f6b55eab4e60195413.jpg" alt="python3-基础教程_第1张图片" width="600" height="1290" style="border:1px solid black;"></a></p> 
 </div> 
</div>
                            </div>
                        </div>
                    </div>
                    <!--PC和WAP自适应版-->
                    <div id="SOHUCS" sid="1364517243332878336"></div>
                    <script type="text/javascript" src="/views/front/js/chanyan.js"></script>
                    <!-- 文章页-底部 动态广告位 -->
                    <div class="youdao-fixed-ad" id="detail_ad_bottom"></div>
                </div>
                <div class="col-md-3">
                    <div class="row" id="ad">
                        <!-- 文章页-右侧1 动态广告位 -->
                        <div id="right-1" class="col-lg-12 col-md-12 col-sm-4 col-xs-4 ad">
                            <div class="youdao-fixed-ad" id="detail_ad_1"> </div>
                        </div>
                        <!-- 文章页-右侧2 动态广告位 -->
                        <div id="right-2" class="col-lg-12 col-md-12 col-sm-4 col-xs-4 ad">
                            <div class="youdao-fixed-ad" id="detail_ad_2"></div>
                        </div>
                        <!-- 文章页-右侧3 动态广告位 -->
                        <div id="right-3" class="col-lg-12 col-md-12 col-sm-4 col-xs-4 ad">
                            <div class="youdao-fixed-ad" id="detail_ad_3"></div>
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </div>
    <div class="container">
        <h4 class="pt20 mb15 mt0 border-top">你可能感兴趣的:(软件杯,python)</h4>
        <div id="paradigm-article-related">
            <div class="recommend-post mb30">
                <ul class="widget-links">
                    <li><a href="/article/1834841410000482304.htm"
                           title="赚佣金平台哪个最好? 盘点5个正规靠谱的佣金赚钱平台" target="_blank">赚佣金平台哪个最好? 盘点5个正规靠谱的佣金赚钱平台</a>
                        <span class="text-muted">好项目高省</span>

                        <div>纵观整个手机挣钱软件市场,电商返利平台赚佣金的平台是最受欢迎的,因为它零成本,零囤货,轻创业,操作简单又赚钱快吧,相对而言,比绝大多数的赚钱软件都要好赚钱些。有的小伙伴做了许多的赚钱软件,到头来还是觉得做返利平台最合适!今天给大家带来三个高佣金的返利平台,大家可以跟你手头的平台对比,毕竟相同的产品总归选择佣金高的做!一、【高省APP】高省app是杭州长孚科技有限公司旗下的一款电商导购应用,为用户打</div>
                    </li>
                    <li><a href="/article/1834841009591250944.htm"
                           title="【雕爷学编程】Arduino智慧农业之智能养殖系统(水质监测和自动投喂)" target="_blank">【雕爷学编程】Arduino智慧农业之智能养殖系统(水质监测和自动投喂)</a>
                        <span class="text-muted">驴友花雕</span>
<a class="tag" taget="_blank" href="/search/%E6%99%BA%E6%85%A7%E5%86%9C%E4%B8%9A/1.htm">智慧农业</a><a class="tag" taget="_blank" href="/search/Arduino/1.htm">Arduino</a><a class="tag" taget="_blank" href="/search/%E6%89%8B%E5%86%8C/1.htm">手册</a><a class="tag" taget="_blank" href="/search/%E6%99%BA%E6%85%A7%E5%86%9C%E4%B8%9A/1.htm">智慧农业</a><a class="tag" taget="_blank" href="/search/%E7%89%A9%E8%81%94%E7%BD%91/1.htm">物联网</a><a class="tag" taget="_blank" href="/search/%E5%B5%8C%E5%85%A5%E5%BC%8F%E7%A1%AC%E4%BB%B6/1.htm">嵌入式硬件</a><a class="tag" taget="_blank" href="/search/Arduino/1.htm">Arduino</a><a class="tag" taget="_blank" href="/search/c%2B%2B/1.htm">c++</a><a class="tag" taget="_blank" href="/search/%E5%8D%95%E7%89%87%E6%9C%BA/1.htm">单片机</a><a class="tag" taget="_blank" href="/search/%E6%99%BA%E8%83%BD%E5%85%BB%E6%AE%96%E7%B3%BB%E7%BB%9F/1.htm">智能养殖系统</a><a class="tag" taget="_blank" href="/search/%E8%87%AA%E5%8A%A8%E6%8A%95%E5%96%82/1.htm">自动投喂</a>
                        <div>Arduino是一个开放源码的电子原型平台,它可以让你用简单的硬件和软件来创建各种互动的项目。Arduino的核心是一个微控制器板,它可以通过一系列的引脚来连接各种传感器、执行器、显示器等外部设备。Arduino的编程是基于C/C++语言的,你可以使用ArduinoIDE(集成开发环境)来编写、编译和上传代码到Arduino板上。Arduino还有一个丰富的库和社区,你可以利用它们来扩展Ardui</div>
                    </li>
                    <li><a href="/article/1834840881845334016.htm"
                           title="如何查看自己的计算机架构" target="_blank">如何查看自己的计算机架构</a>
                        <span class="text-muted">bcb3376</span>
<a class="tag" taget="_blank" href="/search/%E6%9E%B6%E6%9E%84/1.htm">架构</a>
                        <div>如何查看自己的计算机架构计算机架构是指计算机系统的组织结构和功能特性,包括硬件和软件两个方面。不同的计算机架构对应不同的指令集和数据表示方法,对于开发者来说,了解自己的计算机架构是非常重要的。本文将介绍如何查看自己的计算机架构,并提供示例帮助读者更好地理解。如何查看计算机架构要查看自己的计算机架构,可以通过以下几种方法:1.使用系统信息工具大多数操作系统都提供了系统信息工具,可以查看计算机的硬件信</div>
                    </li>
                    <li><a href="/article/1834839244410023936.htm"
                           title="python卡方检验计算pvalue值_Python数据科学:卡方检验" target="_blank">python卡方检验计算pvalue值_Python数据科学:卡方检验</a>
                        <span class="text-muted">CodeWhiz</span>

                        <div>之前已经介绍的变量分析:①相关分析:一个连续变量与一个连续变量间的关系。②双样本t检验:一个二分分类变量与一个连续变量间的关系。③方差分析:一个多分类分类变量与一个连续变量间的关系。本次介绍:卡方检验:一个二分分类变量或多分类分类变量与一个二分分类变量间的关系。如果其中一个变量的分布随着另一个变量的水平不同而发生变化时,那么两个分类变量就有关系。卡方检验并不能展现出两个分类变量相关性的强弱,只能展</div>
                    </li>
                    <li><a href="/article/1834838486901944320.htm"
                           title="sdk和ide" target="_blank">sdk和ide</a>
                        <span class="text-muted">earlene_wyl</span>

                        <div>ide:集成开发环境,是一种辅助程序开发人员开发软件的应用软件。IDE通常包括编程语言编辑器、自动建立工具、通常还包括调试器。有些IDE包含编译器/解释器,如微软的MicrosoftVisualStudio,有些则不包含,如Eclipse、SharpDevelop等,这些IDE是通过调用第三方编译器来实现代码的编译工作的。有时IDE还会包含版本控制系统和一些可以设计图形用户界面的工具。许多支持面向</div>
                    </li>
                    <li><a href="/article/1834838481650675712.htm"
                           title="拼多多官方返利是哪个?拼多多返利软件哪个最好最高" target="_blank">拼多多官方返利是哪个?拼多多返利软件哪个最好最高</a>
                        <span class="text-muted">日常购物小技巧</span>

                        <div>大家好,我是花桃APP商品推荐官:美美,今天给各位说说拼多多官方返利是哪个?拼多多返利软件哪个最好最高答:目前全网最高的是【花桃APP】我也在用,亲测过了!很好用的!说【拼多多返利】之前给大家推荐一款返利APP,【全网返利最高哦!可以对比一下自己在用的返利软件】都是有内部返利和优惠券的,应用商店搜索下载花桃APP即可查询返利佣金。【官方邀请码:999999】目前的话拼多多返利平台最高的就是【花桃A</div>
                    </li>
                    <li><a href="/article/1834837857211084800.htm"
                           title="查看当前计算机CPU架构" target="_blank">查看当前计算机CPU架构</a>
                        <span class="text-muted">raoxiaoya</span>
<a class="tag" taget="_blank" href="/search/Linux/1.htm">Linux</a><a class="tag" taget="_blank" href="/search/windows/1.htm">windows</a>
                        <div>在安装软件的时候,windows上会有32bit,64bit的区别,但是Linux系统下则还需要知道CPU架构,比如amd64,i386,arm64,x86_64,aarch64等等。1、cat/proc/versionLinuxversion3.10.0-1127.10.1.el7.x86_64(mockbuild@kbuilder.bsys.centos.org)(gccversion4.8.</div>
                    </li>
                    <li><a href="/article/1834837603849957376.htm"
                           title="Matlab2024a安装教程" target="_blank">Matlab2024a安装教程</a>
                        <span class="text-muted">是阿宇呢</span>
<a class="tag" taget="_blank" href="/search/%E4%BF%A1%E6%81%AF%E5%8F%AF%E8%A7%86%E5%8C%96/1.htm">信息可视化</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a>
                        <div>MATLAB是一款商业数学软件,用于算法开发、数据可视化、数据分析以及数值计算的高级技术计算语言和交互式环境,主要包括MATLAB和Simulink两大部分,可以进行矩阵运算、绘制函数和数据、实现算法、创建用户界面、连接其他编程语言的程序等,主要应用于工程计算、控制设计、信号处理与通讯、图像处理、信号检测、金融建模设计与分析等领域。1.解压安装包:①鼠标右击【MATLABR2024a(64bit)</div>
                    </li>
                    <li><a href="/article/1834837346336468992.htm"
                           title="来,一杯补酒敬余生!" target="_blank">来,一杯补酒敬余生!</a>
                        <span class="text-muted">舜子的简单日记</span>

                        <div>天气预报说今天有雨,只是这雨几乎没下,难道是昨晚都下完了?不下雨,于是甲方又开始催促防水施工,说实在的,心里挺烦的。最近忽然没有了之前的那种冲劲儿,就是为了完成一件事情可以全身心的投入进去,哪怕是不吃饭、不睡觉也要做好的决心。虽然前两天为了防水工程的正常施工,蹲在工地捡了两天垃圾,感觉已经很拼了。但是,两天下来就觉得累,没有一点成就感。于是就觉得不开心、疲惫、懈怠。是年纪的原因?上次在华山开大组会</div>
                    </li>
                    <li><a href="/article/1834834201300529152.htm"
                           title="Java-后端程序员个人知识总结" target="_blank">Java-后端程序员个人知识总结</a>
                        <span class="text-muted">金肴羽</span>
<a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a>
                        <div>文章目录概要1.编程语言2.数据结构与算法3.数据库知识4.框架和库5.服务器管理6.网络知识7.版本控制8.测试9.安全知识10.系统设计11.编码规范与最佳实践12.持续学习和适应能力概要后端程序员,主要负责应用程序的逻辑、数据库交互、服务器配置以及应用的性能优化等。成为一名优秀的后台程序员,需要掌握以下技能:1.编程语言掌握至少一种后台编程语言JavaPythonHtmlJavaScript</div>
                    </li>
                    <li><a href="/article/1834833948597907456.htm"
                           title="聊一聊风险的分析及缓解" target="_blank">聊一聊风险的分析及缓解</a>
                        <span class="text-muted">Feng.Lee</span>
<a class="tag" taget="_blank" href="/search/%E6%BC%AB%E8%B0%88%E6%B5%8B%E8%AF%95/1.htm">漫谈测试</a><a class="tag" taget="_blank" href="/search/%E9%A1%B9%E7%9B%AE%E7%AE%A1%E7%90%86/1.htm">项目管理</a><a class="tag" taget="_blank" href="/search/%E8%81%8C%E5%9C%BA%E5%92%8C%E5%8F%91%E5%B1%95/1.htm">职场和发展</a><a class="tag" taget="_blank" href="/search/%E7%B3%BB%E7%BB%9F%E6%9E%B6%E6%9E%84/1.htm">系统架构</a>
                        <div>目录一、风险分析二、按照风险发现的频率划分三、项目相关干系人对风险的评估开发人员:项目经理:销售人员:总监和VP:四、风险的化解一、风险分析在软件测试中,我们按照一个常识性的过程来理解风险。哪些事件需要担心?这些事件发生的可能性有多大?一旦发生,对公司产生多大影响?一旦发生,对客户产生多大影响?产品具备什么缓解措施?这些缓解措施有多大可能会失败?处理这些失败的成本有哪些?恢复过程有多困难?事件是一</div>
                    </li>
                    <li><a href="/article/1834831869858902016.htm"
                           title="手机赚钱软件有哪些 手机上能怎么赚钱呢" target="_blank">手机赚钱软件有哪些 手机上能怎么赚钱呢</a>
                        <span class="text-muted">氧惠好项目</span>

                        <div>手机俨然成为了我们必不可少的工具,可以说如影随形,你可以忘记吃饭忘记休息,但是你肯定不会忘记刷手机。因为只要一部手机在手,就可以满足我们所有的需求。比如:出门叫滴滴、肚子饿了叫个美团饿了么、边嗑瓜子边追剧….等等。手机既然整天不离身,那么我们可以用手机来赚钱码?答案是肯定的,而且小编告诉你,现在已经有很多人在使用手机赚钱了,有些人甚至还将手机赚钱作为职业来搞,那我们今天也就来讲讲,怎么利用一台手机</div>
                    </li>
                    <li><a href="/article/1834828021232660480.htm"
                           title="Eclipse SDK与 IDE 有什么区别,是什么意思?" target="_blank">Eclipse SDK与 IDE 有什么区别,是什么意思?</a>
                        <span class="text-muted">guo_wen_qiang</span>

                        <div>SDK:全称SoftwareDevelopmentKit,软件开发工具包。IDE:全称IntegratedDevelopment,集成开发环境。SDK是一个能够进行开发的环境,是一个基本的环境,可以添加一些其他的功能,添加插件帮助实现想要的功能。这种将想要的插件安装在SDK上的环境称为IDE</div>
                    </li>
                    <li><a href="/article/1834827539000946688.htm"
                           title="思维导图-ProcessOn" target="_blank">思维导图-ProcessOn</a>
                        <span class="text-muted">佛系猿</span>

                        <div>今天介绍一款特别好用的流程图、思维导图软件ProcessOn用途:在线画流程图、思维导图、UI原型图、UML、网络拓扑图、组织结构图等各种模板供你选择image支持团队协作支持不同格式下载image更多查看官网最后附上做的效果图:image</div>
                    </li>
                    <li><a href="/article/1834826509500641280.htm"
                           title="python 卡方检验_Python-卡方检验" target="_blank">python 卡方检验_Python-卡方检验</a>
                        <span class="text-muted">cunzai1985</span>
<a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/numpy/1.htm">numpy</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%88%86%E6%9E%90/1.htm">数据分析</a><a class="tag" taget="_blank" href="/search/%E6%9C%BA%E5%99%A8%E5%AD%A6%E4%B9%A0/1.htm">机器学习</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E6%8C%96%E6%8E%98/1.htm">数据挖掘</a>
                        <div>python卡方检验Python-卡方检验(Python-Chi-SquareTest)Chi-Squaretestisastatisticalmethodtodetermineiftwocategoricalvariableshaveasignificantcorrelationbetweenthem.Boththosevariablesshouldbefromsamepopulationand</div>
                    </li>
                    <li><a href="/article/1834825373909610496.htm"
                           title="centos下安装python3" target="_blank">centos下安装python3</a>
                        <span class="text-muted">i0208</span>
<a class="tag" taget="_blank" href="/search/centos/1.htm">centos</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a>
                        <div>Centos7默认自带了Python2.7版本,但是因为项目需要使用Python3.x你可以按照此文的三个方法进行安装.注:本文示例安装版本为Python3.5,一、Python源代码编译安装安装必要工具yum-utils,它的功能是管理repository及扩展包的工具(主要是针对repository)$sudoyuminstallyum-utils使用yum-builddep为Python3构</div>
                    </li>
                    <li><a href="/article/1834825245815566336.htm"
                           title="【Python・统计学】威尔科克森符号秩检验/Wilcoxon signed-rank test(原理及代码)" target="_blank">【Python・统计学】威尔科克森符号秩检验/Wilcoxon signed-rank test(原理及代码)</a>
                        <span class="text-muted">TUTO_TUTO</span>
<a class="tag" taget="_blank" href="/search/%E7%BB%9F%E8%AE%A1%E5%AD%A6/1.htm">统计学</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E5%AD%A6%E4%B9%A0/1.htm">学习</a><a class="tag" taget="_blank" href="/search/%E7%AC%94%E8%AE%B0/1.htm">笔记</a>
                        <div>前言自学笔记,分享给对统计学原理不太清楚但需要在论文中用到的小伙伴,欢迎大佬们补充或绕道。ps:本文不涉及公式讲解(文科生小白友好体质)~(部分定义等来源于知乎百度等)本文重点:威尔科克森符号秩检验(英文名:Wilcoxonsigned-ranktest)【1.简单原理和步骤】【2.应用条件】【3.数据实例以及Python代码】1.简单原理和步骤威尔科克森符号秩检验是一种非参数检验的方法,需要数据</div>
                    </li>
                    <li><a href="/article/1834825246964805632.htm"
                           title="【Python・统计学】Kruskal-Wallis检验/H检验(原理及代码)" target="_blank">【Python・统计学】Kruskal-Wallis检验/H检验(原理及代码)</a>
                        <span class="text-muted">TUTO_TUTO</span>
<a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E7%BB%9F%E8%AE%A1%E5%AD%A6/1.htm">统计学</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E5%AD%A6%E4%B9%A0/1.htm">学习</a><a class="tag" taget="_blank" href="/search/%E7%AC%94%E8%AE%B0/1.htm">笔记</a>
                        <div>前言自学笔记,分享给对统计学原理不太清楚但需要在论文中用到的小伙伴,欢迎大佬们补充或绕道。ps:本文不涉及公式讲解(文科生小白友好体质)~(部分定义等来源于知乎百度等)本文重点:Kruskal-Wallis检验(Kruskal-Wallistest),也称H检验【1.定义和简单原理】【2.应用条件】【3.数据实例以及Python代码】【4.多重比较(例:Dunn检验)】1.定义和简单原理Krusk</div>
                    </li>
                    <li><a href="/article/1834825116668751872.htm"
                           title="【Python・统计学】单因素方差分析(简单原理及代码)" target="_blank">【Python・统计学】单因素方差分析(简单原理及代码)</a>
                        <span class="text-muted">TUTO_TUTO</span>
<a class="tag" taget="_blank" href="/search/%E7%BB%9F%E8%AE%A1%E5%AD%A6/1.htm">统计学</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E5%AD%A6%E4%B9%A0/1.htm">学习</a><a class="tag" taget="_blank" href="/search/%E7%AC%94%E8%AE%B0/1.htm">笔记</a>
                        <div>前言自学笔记,分享给对统计学原理不太清楚但需要在论文中用到的小伙伴,欢迎大佬们补充或绕道。ps:本文不涉及公式讲解(文科生小白友好体质)~本文重点:单因素方差分析(以下:方差分析)【1.方差分析简单原理和前提条件】【2.方差分析和t检验的区别】【3.方差分析代码(配对/独立+事后检验+效应量)】1.方差分析简单原理方差分析(ANOVA)又称“变异数分析”或“F检验”,是由罗纳德·费雪爵士发明的,用</div>
                    </li>
                    <li><a href="/article/1834824485384056832.htm"
                           title="【15.4 python中,wxPython框架的BoxSizer布局】" target="_blank">【15.4 python中,wxPython框架的BoxSizer布局】</a>
                        <span class="text-muted">wang151038606</span>
<a class="tag" taget="_blank" href="/search/python%E8%AF%AD%E8%A8%80%E5%85%A5%E9%97%A8%E5%AD%A6%E4%B9%A0/1.htm">python语言入门学习</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a>
                        <div>python中,以wxPython框架为例,介绍一下BoxSizer布局在wxPython中,BoxSizer是一种常用的布局管理器,它允许你以水平或垂直的方式排列控件。BoxSizer会基于控件的请求大小以及容器中可用的空间来动态地调整控件的大小和位置。它非常适合于创建简单的一维布局,如工具栏、菜单栏或侧边栏等。在wxPython中,除了BoxSizer和GridSizer之外,还有其他几种si</div>
                    </li>
                    <li><a href="/article/1834824485933510656.htm"
                           title="【3.6 python中的numpy编写一个“手写数字识”的神经网络】" target="_blank">【3.6 python中的numpy编写一个“手写数字识”的神经网络】</a>
                        <span class="text-muted">wang151038606</span>
<a class="tag" taget="_blank" href="/search/%E6%B7%B1%E5%BA%A6%E5%AD%A6%E4%B9%A0%E5%85%A5%E9%97%A8/1.htm">深度学习入门</a><a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/numpy/1.htm">numpy</a><a class="tag" taget="_blank" href="/search/%E7%A5%9E%E7%BB%8F%E7%BD%91%E7%BB%9C/1.htm">神经网络</a>
                        <div>3.6python中的numpy编写一个“手写数字识”的神经网络要使用Python中的NumPy库从头开始编写一个“手写数字识别”的神经网络,我们通常会处理MNIST数据集,这是一个广泛使用的包含手写数字的图像数据集。但是,完全用NumPy来实现神经网络(包括数据的加载、预处理、模型定义、前向传播、损失计算、反向传播和权重更新)是一个相当复杂的任务,因为NumPy本身不提供自动微分或高级优化算法(</div>
                    </li>
                    <li><a href="/article/1834819445147660288.htm"
                           title="Python酷库之旅-第三方库Pandas(115)" target="_blank">Python酷库之旅-第三方库Pandas(115)</a>
                        <span class="text-muted">神奇夜光杯</span>
<a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/pandas/1.htm">pandas</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a><a class="tag" taget="_blank" href="/search/%E4%BA%BA%E5%B7%A5%E6%99%BA%E8%83%BD/1.htm">人工智能</a><a class="tag" taget="_blank" href="/search/%E6%A0%87%E5%87%86%E5%BA%93%E5%8F%8A%E7%AC%AC%E4%B8%89%E6%96%B9%E5%BA%93/1.htm">标准库及第三方库</a><a class="tag" taget="_blank" href="/search/excel/1.htm">excel</a><a class="tag" taget="_blank" href="/search/%E5%AD%A6%E4%B9%A0%E4%B8%8E%E6%88%90%E9%95%BF/1.htm">学习与成长</a>
                        <div>目录一、用法精讲506、pandas.DataFrame.rank方法506-1、语法506-2、参数506-3、功能506-4、返回值506-5、说明506-6、用法506-6-1、数据准备506-6-2、代码示例506-6-3、结果输出507、pandas.DataFrame.round方法507-1、语法507-2、参数507-3、功能507-4、返回值507-5、说明507-6、用法507</div>
                    </li>
                    <li><a href="/article/1834818864916033536.htm"
                           title="合适上班族可以赚钱的软件真实可靠(可提现到微信的副业软件)" target="_blank">合适上班族可以赚钱的软件真实可靠(可提现到微信的副业软件)</a>
                        <span class="text-muted">小推客</span>

                        <div>作为一名编辑,在副业领域内也是有一定的研究的,比如我们刚入行的时候,我看到有这样的一个栏目的时候,我就觉得比较奇怪,难道很多职场人都喜欢做副业兼职的吗?当时,我带有这样的疑问,所以,我就问我的主管,一个97年的美女,我主管说,我们全工作室的人都做副业和兼职,基本上都是一些手机上的副业兼职,所以当时我们也要了解这个行业,我如今进入工作室有5个月的时间了,对于这方面也有了足够的研究。因此,我也靠着一些</div>
                    </li>
                    <li><a href="/article/1834818436371410944.htm"
                           title="Python 安装 Selenium 报错解决方案:全方位排错指南" target="_blank">Python 安装 Selenium 报错解决方案:全方位排错指南</a>
                        <span class="text-muted">小柒笔记</span>
<a class="tag" taget="_blank" href="/search/python/1.htm">python</a><a class="tag" taget="_blank" href="/search/selenium/1.htm">selenium</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a>
                        <div>引言在尝试使用pip安装Selenium库时,您可能会遇到中断报错,这通常是由于多种原因造成的,如网络问题、权限问题或依赖项缺失等。本文将指导您如何解决这一常见问题。一、检查网络连接首先,确保您的网络连接稳定。pip安装过程中需要从互联网下载包,因此网络不稳定可能导致安装失败。二、使用管理员权限运行在Windows系统中,尝试使用管理员权限运行命令提示符或PowerShell。右键点击命令提示符或</div>
                    </li>
                    <li><a href="/article/1834818182343389184.htm"
                           title="[ IDE ] 什么是SDK" target="_blank">[ IDE ] 什么是SDK</a>
                        <span class="text-muted">ERIC-ZI</span>
<a class="tag" taget="_blank" href="/search/IDE/1.htm">IDE</a><a class="tag" taget="_blank" href="/search/IDE/1.htm">IDE</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E7%8E%AF%E5%A2%83/1.htm">开发环境</a>
                        <div>一、定义在嵌入式系统开发中,SDK(SoftwareDevelopmentKit,软件开发工具包)是一个综合性的工具集合,它被设计用于帮助开发者更有效地为特定的硬件平台编写软件。嵌入式SDK通常包含一系列的工具、库文件、文档和示例代码,旨在简化开发过程并提高开发效率。二、SDK的主要组成编译器和链接器:这些工具用于将开发者编写的源代码转化为目标硬件可以理解和执行的机器码。库文件:库文件包含了一些预</div>
                    </li>
                    <li><a href="/article/1834817467671736320.htm"
                           title="3ds-max导入3D模型" target="_blank">3ds-max导入3D模型</a>
                        <span class="text-muted">转身丶即天涯</span>

                        <div>前言之前,我们所接触的模型都是我们自己画的,但是实际使用中,很多情况都是使用网络中下载的素材。所以,我们需要学会将网络中素材下载下来,并导入到视图中使用。从网络找素材百度一搜有很多,我从3d溜溜网下载了一个椅子模型。image.png下载过程省略...将素材导入“视口区”打开3ds-max软件,找到下载的模型,然后解压,找到.max结尾的文件,然后把文件拖入3ds-max中。image.png然后</div>
                    </li>
                    <li><a href="/article/1834817174032707584.htm"
                           title="MATLAB中的代码覆盖测试:深入指南与实践应用" target="_blank">MATLAB中的代码覆盖测试:深入指南与实践应用</a>
                        <span class="text-muted">2401_85812026</span>
<a class="tag" taget="_blank" href="/search/matlab/1.htm">matlab</a><a class="tag" taget="_blank" href="/search/%E5%BC%80%E5%8F%91%E8%AF%AD%E8%A8%80/1.htm">开发语言</a>
                        <div>在软件测试领域,代码覆盖测试是一种重要的技术,用于评估测试用例的完整性和有效性。在MATLAB环境中,代码覆盖测试可以帮助开发者确保他们的代码在各种条件下都能正常工作,并且能够发现可能被忽视的错误。本文将详细介绍如何在MATLAB中进行代码覆盖测试,包括测试的类型、工具和实践方法。1.代码覆盖测试的基本概念代码覆盖测试旨在通过测试用例执行代码中的不同部分,以确保代码的每个部分都经过了验证。在MAT</div>
                    </li>
                    <li><a href="/article/1834816166367948800.htm"
                           title="使用vllIm部署大语言模型" target="_blank">使用vllIm部署大语言模型</a>
                        <span class="text-muted">添砖JAVA的小墨</span>
<a class="tag" taget="_blank" href="/search/%E6%9C%BA%E5%99%A8%E5%AD%A6%E4%B9%A0/1.htm">机器学习</a>
                        <div>使用vllm部署大语言模型一般需要以下步骤:一、准备工作1.系统要求-操作系统:常见的Linux发行版(如Ubuntu、CentOS)或Windows(通过WSL)。-GPU支持:NVIDIAGPU并安装了适当的驱动程序。-足够的内存和存储空间。2.安装依赖-Python3.8及以上版本。-CUDA工具包(根据GPU型号选择合适的版本)。二、安装vllm1.创建虚拟环境(推荐)-使用Conda:c</div>
                    </li>
                    <li><a href="/article/1834812640262713344.htm"
                           title="低代码平台与传统开发平台的主要区别是什么?" target="_blank">低代码平台与传统开发平台的主要区别是什么?</a>
                        <span class="text-muted">勤研科技</span>
<a class="tag" taget="_blank" href="/search/%E4%BD%8E%E4%BB%A3%E7%A0%81%E5%BC%80%E5%8F%91%E6%96%B0%E8%A7%86%E8%A7%92/1.htm">低代码开发新视角</a><a class="tag" taget="_blank" href="/search/%E4%BD%8E%E4%BB%A3%E7%A0%81/1.htm">低代码</a>
                        <div>在当今快速发展的数字化时代,企业和个人对软件开发的需求日益增长。然而,传统的软件开发方式往往面临着开发周期长、成本高、技术门槛高等问题。为了应对这些挑战,低代码平台应运而生,成为一种新兴的开发方式。低代码平台通过简化开发流程,降低了技术门槛,使得非技术用户也能参与到应用开发中来。低代码平台的核心理念是通过可视化工具和预设模板,让用户能够快速构建应用,而无需深入的编程知识。这种方式不仅提高了开发效率</div>
                    </li>
                    <li><a href="/article/1834811757529493504.htm"
                           title="FreeRTOS操作系统(详细速通篇)——— 第十五章(完结)" target="_blank">FreeRTOS操作系统(详细速通篇)——— 第十五章(完结)</a>
                        <span class="text-muted">给生活加糖!</span>
<a class="tag" taget="_blank" href="/search/%E5%BF%AB%E9%80%9F%E9%80%9A%E5%85%B3FreeRTOS/1.htm">快速通关FreeRTOS</a><a class="tag" taget="_blank" href="/search/stm32/1.htm">stm32</a><a class="tag" taget="_blank" href="/search/FreeRTOS/1.htm">FreeRTOS</a><a class="tag" taget="_blank" href="/search/%E5%8D%95%E7%89%87%E6%9C%BA/1.htm">单片机</a><a class="tag" taget="_blank" href="/search/%E5%B5%8C%E5%85%A5%E5%BC%8F/1.htm">嵌入式</a><a class="tag" taget="_blank" href="/search/%E5%B5%8C%E5%85%A5%E5%BC%8F%E8%BD%AF%E4%BB%B6/1.htm">嵌入式软件</a><a class="tag" taget="_blank" href="/search/c%E8%AF%AD%E8%A8%80/1.htm">c语言</a><a class="tag" taget="_blank" href="/search/%E6%93%8D%E4%BD%9C%E7%B3%BB%E7%BB%9F/1.htm">操作系统</a>
                        <div>本专栏将对FreeRTOS进行快速讲解,带你了解并使用FreeRTOS的各部分内容。适用于快速了解FreeRTOS并进行开发、突击面试、对新手小白非常友好。期待您的后续关注和订阅!目录软件定时器和低功耗模式1软件定时器1.1什么是定时器?1.2软件定时器的优缺点1.3FreeRTOS软件定时器特点1.4软件定时器的状态及转换1.4.1定时器状态1.4.2定时器周期1.5结构体及API函数1.5.1</div>
                    </li>
                                <li><a href="/article/120.htm"
                                       title="web前段跨域nginx代理配置" target="_blank">web前段跨域nginx代理配置</a>
                                    <span class="text-muted">刘正强</span>
<a class="tag" taget="_blank" href="/search/nginx/1.htm">nginx</a><a class="tag" taget="_blank" href="/search/cms/1.htm">cms</a><a class="tag" taget="_blank" href="/search/Web/1.htm">Web</a>
                                    <div>nginx代理配置可参考server部分 
 
server { 
        listen       80; 
        server_name  localhost; 
 
</div>
                                </li>
                                <li><a href="/article/247.htm"
                                       title="spring学习笔记" target="_blank">spring学习笔记</a>
                                    <span class="text-muted">caoyong</span>
<a class="tag" taget="_blank" href="/search/spring/1.htm">spring</a>
                                    <div>一、概述 
    a>、核心技术 : IOC与AOP 
 b>、开发为什么需要面向接口而不是实现 
     接口降低一个组件与整个系统的藕合程度,当该组件不满足系统需求时,可以很容易的将该组件从系统中替换掉,而不会对整个系统产生大的影响 
 c>、面向接口编口编程的难点在于如何对接口进行初始化,(使用工厂设计模式) </div>
                                </li>
                                <li><a href="/article/374.htm"
                                       title="Eclipse打开workspace提示工作空间不可用" target="_blank">Eclipse打开workspace提示工作空间不可用</a>
                                    <span class="text-muted">0624chenhong</span>
<a class="tag" taget="_blank" href="/search/eclipse/1.htm">eclipse</a>
                                    <div>做项目的时候,难免会用到整个团队的代码,或者上一任同事创建的workspace, 
1.电脑切换账号后,Eclipse打开时,会提示Eclipse对应的目录锁定,无法访问,根据提示,找到对应目录,G:\eclipse\configuration\org.eclipse.osgi\.manager,其中文件.fileTableLock提示被锁定。 
解决办法,删掉.fileTableLock文件,重</div>
                                </li>
                                <li><a href="/article/501.htm"
                                       title="Javascript 面向对面写法的必要性?" target="_blank">Javascript 面向对面写法的必要性?</a>
                                    <span class="text-muted">一炮送你回车库</span>
<a class="tag" taget="_blank" href="/search/JavaScript/1.htm">JavaScript</a>
                                    <div>现在Javascript面向对象的方式来写页面很流行,什么纯javascript的mvc框架都出来了:ember 
这是javascript层的mvc框架哦,不是j2ee的mvc框架 
  
我想说的是,javascript本来就不是一门面向对象的语言,用它写出来的面向对象的程序,本身就有些别扭,很多人提到js的面向对象首先提的是:复用性。那么我请问你写的js里有多少是可以复用的,用fu</div>
                                </li>
                                <li><a href="/article/628.htm"
                                       title="js array对象的迭代方法" target="_blank">js array对象的迭代方法</a>
                                    <span class="text-muted">换个号韩国红果果</span>
<a class="tag" taget="_blank" href="/search/array/1.htm">array</a>
                                    <div>1.forEach 该方法接受一个函数作为参数, 对数组中的每个元素 
使用该函数  return 语句失效 
 

function square(num) {
print(num, num * num);
}
var nums = [1,2,3,4,5,6,7,8,9,10];
nums.forEach(square);
 
2.every 该方法接受一个返回值为布尔类型</div>
                                </li>
                                <li><a href="/article/755.htm"
                                       title="对Hibernate缓存机制的理解" target="_blank">对Hibernate缓存机制的理解</a>
                                    <span class="text-muted">归来朝歌</span>
<a class="tag" taget="_blank" href="/search/session/1.htm">session</a><a class="tag" taget="_blank" href="/search/%E4%B8%80%E7%BA%A7%E7%BC%93%E5%AD%98/1.htm">一级缓存</a><a class="tag" taget="_blank" href="/search/%E5%AF%B9%E8%B1%A1%E6%8C%81%E4%B9%85%E5%8C%96/1.htm">对象持久化</a>
                                    <div>在hibernate中session一级缓存机制中,有这么一种情况: 
问题描述:我需要new一个对象,对它的几个字段赋值,但是有一些属性并没有进行赋值,然后调用 
session.save()方法,在提交事务后,会出现这样的情况: 
1:在数据库中有默认属性的字段的值为空 
2:既然是持久化对象,为什么在最后对象拿不到默认属性的值? 
通过调试后解决方案如下: 
对于问题一,如你在数据库里设置了</div>
                                </li>
                                <li><a href="/article/882.htm"
                                       title="WebService调用错误合集" target="_blank">WebService调用错误合集</a>
                                    <span class="text-muted">darkranger</span>
<a class="tag" taget="_blank" href="/search/webservice/1.htm">webservice</a>
                                    <div> Java.Lang.NoClassDefFoundError: Org/Apache/Commons/Discovery/Tools/DiscoverSingleton   
调用接口出错, 
一个简单的WebService 
import org.apache.axis.client.Call;import org.apache.axis.client.Service; 
首先必不可</div>
                                </li>
                                <li><a href="/article/1009.htm"
                                       title="JSP和Servlet的中文乱码处理" target="_blank">JSP和Servlet的中文乱码处理</a>
                                    <span class="text-muted">aijuans</span>
<a class="tag" taget="_blank" href="/search/Java+Web/1.htm">Java Web</a>
                                    <div>JSP和Servlet的中文乱码处理 
前几天学习了JSP和Servlet中有关中文乱码的一些问题,写成了博客,今天进行更新一下。应该是可以解决日常的乱码问题了。现在作以下总结希望对需要的人有所帮助。我也是刚学,所以有不足之处希望谅解。 
一、表单提交时出现乱码: 
在进行表单提交的时候,经常提交一些中文,自然就避免不了出现中文乱码的情况,对于表单来说有两种提交方式:get和post提交方式。所以</div>
                                </li>
                                <li><a href="/article/1136.htm"
                                       title="面试经典六问" target="_blank">面试经典六问</a>
                                    <span class="text-muted">atongyeye</span>
<a class="tag" taget="_blank" href="/search/%E5%B7%A5%E4%BD%9C/1.htm">工作</a><a class="tag" taget="_blank" href="/search/%E9%9D%A2%E8%AF%95/1.htm">面试</a>
                                    <div>题记:因为我不善沟通,所以在面试中经常碰壁,看了网上太多面试宝典,基本上不太靠谱。只好自己总结,并试着根据最近工作情况完成个人答案。以备不时之需。 
 
以下是人事了解应聘者情况的最典型的六个问题: 
 
 
1 简单自我介绍  
 
关于这个问题,主要为了弄清两件事,一是了解应聘者的背景,二是应聘者将这些背景信息组织成合适语言的能力。 
 
我的回答:(针对技术面试回答,如果是人事面试,可以就掌</div>
                                </li>
                                <li><a href="/article/1263.htm"
                                       title="contentResolver.query()参数详解" target="_blank">contentResolver.query()参数详解</a>
                                    <span class="text-muted">百合不是茶</span>
<a class="tag" taget="_blank" href="/search/android/1.htm">android</a><a class="tag" taget="_blank" href="/search/query%28%29%E8%AF%A6%E8%A7%A3/1.htm">query()详解</a>
                                    <div>收藏csdn的博客,介绍的比较详细,新手值得一看 1.获取联系人姓名 
一个简单的例子,这个函数获取设备上所有的联系人ID和联系人NAME。    
[java]  
view plain 
copy       
 
 public void fetchAllContacts() {   
    </div>
                                </li>
                                <li><a href="/article/1390.htm"
                                       title="ora-00054:resource busy and acquire with nowait specified解决方法" target="_blank">ora-00054:resource busy and acquire with nowait specified解决方法</a>
                                    <span class="text-muted">bijian1013</span>
<a class="tag" taget="_blank" href="/search/oracle/1.htm">oracle</a><a class="tag" taget="_blank" href="/search/%E6%95%B0%E6%8D%AE%E5%BA%93/1.htm">数据库</a><a class="tag" taget="_blank" href="/search/kill/1.htm">kill</a><a class="tag" taget="_blank" href="/search/nowait/1.htm">nowait</a>
                                    <div>        当某个数据库用户在数据库中插入、更新、删除一个表的数据,或者增加一个表的主键时或者表的索引时,常常会出现ora-00054:resource busy and acquire with nowait specified这样的错误。主要是因为有事务正在执行(或者事务已经被锁),所有导致执行不成功。 
1.下面的语句</div>
                                </li>
                                <li><a href="/article/1517.htm"
                                       title="web 开发乱码" target="_blank">web 开发乱码</a>
                                    <span class="text-muted">征客丶</span>
<a class="tag" taget="_blank" href="/search/spring/1.htm">spring</a><a class="tag" taget="_blank" href="/search/Web/1.htm">Web</a>
                                    <div>以下前端都是 utf-8 字符集编码 
 
一、后台接收 
1.1、 get 请求乱码 
get 请求中,请求参数在请求头中; 
乱码解决方法: 
a、通过在web 服务器中配置编码格式:tomcat 中,在 Connector 中添加URIEncoding="UTF-8"; 
 
1.2、post 请求乱码 
post 请求中,请求参数分两部份, 
1.2.1、url?参数,</div>
                                </li>
                                <li><a href="/article/1644.htm"
                                       title="【Spark十六】: Spark SQL第二部分数据源和注册表的几种方式" target="_blank">【Spark十六】: Spark SQL第二部分数据源和注册表的几种方式</a>
                                    <span class="text-muted">bit1129</span>
<a class="tag" taget="_blank" href="/search/spark/1.htm">spark</a>
                                    <div>Spark SQL数据源和表的Schema 
 
  case class  
  apply schema  
  parquet  
  json  
 JSON数据源 准备源数据 
{"name":"Jack", "age": 12, "addr":{"city":"beijing&</div>
                                </li>
                                <li><a href="/article/1771.htm"
                                       title="JVM学习之:调优总结 -Xms -Xmx -Xmn -Xss" target="_blank">JVM学习之:调优总结 -Xms -Xmx -Xmn -Xss</a>
                                    <span class="text-muted">BlueSkator</span>
<a class="tag" taget="_blank" href="/search/-Xss/1.htm">-Xss</a><a class="tag" taget="_blank" href="/search/-Xmn/1.htm">-Xmn</a><a class="tag" taget="_blank" href="/search/-Xms/1.htm">-Xms</a><a class="tag" taget="_blank" href="/search/-Xmx/1.htm">-Xmx</a>
                                    <div>  
堆大小设置JVM 中最大堆大小有三方面限制:相关操作系统的数据模型(32-bt还是64-bit)限制;系统的可用虚拟内存限制;系统的可用物理内存限制。32位系统下,一般限制在1.5G~2G;64为操作系统对内存无限制。我在Windows Server 2003 系统,3.5G物理内存,JDK5.0下测试,最大可设置为1478m。典型设置: 
 
 java -Xmx355</div>
                                </li>
                                <li><a href="/article/1898.htm"
                                       title="jqGrid 各种参数 详解(转帖)" target="_blank">jqGrid 各种参数 详解(转帖)</a>
                                    <span class="text-muted">BreakingBad</span>
<a class="tag" taget="_blank" href="/search/jqGrid/1.htm">jqGrid</a>
                                    <div>  
jqGrid 各种参数 详解   分类: 
源代码分享 
个人随笔请勿参考 
解决开发问题 2012-05-09 20:29   84282人阅读   
评论(22)   
收藏   
举报   
jquery 
服务器 
parameters 
function 
ajax 
string      </div>
                                </li>
                                <li><a href="/article/2025.htm"
                                       title="读《研磨设计模式》-代码笔记-代理模式-Proxy" target="_blank">读《研磨设计模式》-代码笔记-代理模式-Proxy</a>
                                    <span class="text-muted">bylijinnan</span>
<a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E8%AE%BE%E8%AE%A1%E6%A8%A1%E5%BC%8F/1.htm">设计模式</a>
                                    <div>声明: 本文只为方便我个人查阅和理解,详细的分析以及源代码请移步 原作者的博客http://chjavach.iteye.com/ 
 
 



import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;

/*
 * 下面</div>
                                </li>
                                <li><a href="/article/2152.htm"
                                       title="应用升级iOS8中遇到的一些问题" target="_blank">应用升级iOS8中遇到的一些问题</a>
                                    <span class="text-muted">chenhbc</span>
<a class="tag" taget="_blank" href="/search/ios8/1.htm">ios8</a><a class="tag" taget="_blank" href="/search/%E5%8D%87%E7%BA%A7iOS8/1.htm">升级iOS8</a>
                                    <div>1、很奇怪的问题,登录界面,有一个判断,如果不存在某个值,则跳转到设置界面,ios8之前的系统都可以正常跳转,iOS8中代码已经执行到下一个界面了,但界面并没有跳转过去,而且这个值如果设置过的话,也是可以正常跳转过去的,这个问题纠结了两天多,之前的判断我是在 
-(void)viewWillAppear:(BOOL)animated 
 中写的,最终的解决办法是把判断写在 
-(void</div>
                                </li>
                                <li><a href="/article/2279.htm"
                                       title="工作流与自组织的关系?" target="_blank">工作流与自组织的关系?</a>
                                    <span class="text-muted">comsci</span>
<a class="tag" taget="_blank" href="/search/%E8%AE%BE%E8%AE%A1%E6%A8%A1%E5%BC%8F/1.htm">设计模式</a><a class="tag" taget="_blank" href="/search/%E5%B7%A5%E4%BD%9C/1.htm">工作</a>
                                    <div>  目前的工作流系统中的节点及其相互之间的连接是事先根据管理的实际需要而绘制好的,这种固定的模式在实际的运用中会受到很多限制,特别是节点之间的依存关系是固定的,节点的处理不考虑到流程整体的运行情况,细节和整体间的关系是脱节的,那么我们提出一个新的观点,一个流程是否可以通过节点的自组织运动来自动生成呢?这种流程有什么实际意义呢? 
 
  这里有篇论文,摘要是:“针对网格中的服务</div>
                                </li>
                                <li><a href="/article/2406.htm"
                                       title="Oracle11.2新特性之INSERT提示IGNORE_ROW_ON_DUPKEY_INDEX" target="_blank">Oracle11.2新特性之INSERT提示IGNORE_ROW_ON_DUPKEY_INDEX</a>
                                    <span class="text-muted">daizj</span>
<a class="tag" taget="_blank" href="/search/oracle/1.htm">oracle</a>
                                    <div>insert提示IGNORE_ROW_ON_DUPKEY_INDEX 
 
转自:http://space.itpub.net/18922393/viewspace-752123 
 
在 insert into tablea ...select * from tableb中,如果存在唯一约束,会导致整个insert操作失败。使用IGNORE_ROW_ON_DUPKEY_INDEX提示,会忽略唯一</div>
                                </li>
                                <li><a href="/article/2533.htm"
                                       title="二叉树:堆" target="_blank">二叉树:堆</a>
                                    <span class="text-muted">dieslrae</span>
<a class="tag" taget="_blank" href="/search/%E4%BA%8C%E5%8F%89%E6%A0%91/1.htm">二叉树</a>
                                    <div>    这里说的堆其实是一个完全二叉树,每个节点都不小于自己的子节点,不要跟jvm的堆搞混了.由于是完全二叉树,可以用数组来构建.用数组构建树的规则很简单: 
    一个节点的父节点下标为: (当前下标 - 1)/2 
    一个节点的左节点下标为: 当前下标 * 2 + 1 
  &</div>
                                </li>
                                <li><a href="/article/2660.htm"
                                       title="C语言学习八结构体" target="_blank">C语言学习八结构体</a>
                                    <span class="text-muted">dcj3sjt126com</span>
<a class="tag" taget="_blank" href="/search/c/1.htm">c</a>
                                    <div>为什么需要结构体,看代码 
# include <stdio.h>

struct Student	//定义一个学生类型,里面有age, score, sex, 然后可以定义这个类型的变量
{
	int age;
	float score;
	char sex;
}

int main(void)
{
	struct Student st = {80, 66.6,</div>
                                </li>
                                <li><a href="/article/2787.htm"
                                       title="centos安装golang" target="_blank">centos安装golang</a>
                                    <span class="text-muted">dcj3sjt126com</span>
<a class="tag" taget="_blank" href="/search/centos/1.htm">centos</a>
                                    <div>#在国内镜像下载二进制包 
wget -c  http://www.golangtc.com/static/go/go1.4.1.linux-amd64.tar.gz 
tar -C /usr/local -xzf go1.4.1.linux-amd64.tar.gz 
  
#把golang的bin目录加入全局环境变量 
cat >>/etc/profile<</div>
                                </li>
                                <li><a href="/article/2914.htm"
                                       title="10.性能优化-监控-MySQL慢查询" target="_blank">10.性能优化-监控-MySQL慢查询</a>
                                    <span class="text-muted">frank1234</span>
<a class="tag" taget="_blank" href="/search/%E6%80%A7%E8%83%BD%E4%BC%98%E5%8C%96/1.htm">性能优化</a><a class="tag" taget="_blank" href="/search/MySQL%E6%85%A2%E6%9F%A5%E8%AF%A2/1.htm">MySQL慢查询</a>
                                    <div>1.记录慢查询配置 
show variables where variable_name like 'slow%' ; --查看默认日志路径 
查询结果:--不用的机器可能不同 
slow_query_log_file=/var/lib/mysql/centos-slow.log 
 
修改mysqld配置文件:/usr /my.cnf[一般在/etc/my.cnf,本机在/user/my.cn</div>
                                </li>
                                <li><a href="/article/3041.htm"
                                       title="Java父类取得子类类名" target="_blank">Java父类取得子类类名</a>
                                    <span class="text-muted">happyqing</span>
<a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/this/1.htm">this</a><a class="tag" taget="_blank" href="/search/%E7%88%B6%E7%B1%BB/1.htm">父类</a><a class="tag" taget="_blank" href="/search/%E5%AD%90%E7%B1%BB/1.htm">子类</a><a class="tag" taget="_blank" href="/search/%E7%B1%BB%E5%90%8D/1.htm">类名</a>
                                    <div>  
在继承关系中,不管父类还是子类,这些类里面的this都代表了最终new出来的那个类的实例对象,所以在父类中你可以用this获取到子类的信息! 
  
package com.urthinker.module.test;

import org.junit.Test;

abstract class BaseDao<T> {
	public void </div>
                                </li>
                                <li><a href="/article/3168.htm"
                                       title="Spring3.2新注解@ControllerAdvice" target="_blank">Spring3.2新注解@ControllerAdvice</a>
                                    <span class="text-muted">jinnianshilongnian</span>
<a class="tag" taget="_blank" href="/search/%40Controller/1.htm">@Controller</a>
                                    <div>@ControllerAdvice,是spring3.2提供的新注解,从名字上可以看出大体意思是控制器增强。让我们先看看@ControllerAdvice的实现: 
  
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Component
public @interface Co</div>
                                </li>
                                <li><a href="/article/3295.htm"
                                       title="Java spring mvc多数据源配置" target="_blank">Java spring mvc多数据源配置</a>
                                    <span class="text-muted">liuxihope</span>
<a class="tag" taget="_blank" href="/search/spring/1.htm">spring</a>
                                    <div>转自:http://www.itpub.net/thread-1906608-1-1.html 
 
 
1、首先配置两个数据库 
 
<bean id="dataSourceA"         class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close&quo</div>
                                </li>
                                <li><a href="/article/3422.htm"
                                       title="第12章 Ajax(下)" target="_blank">第12章 Ajax(下)</a>
                                    <span class="text-muted">onestopweb</span>
<a class="tag" taget="_blank" href="/search/Ajax/1.htm">Ajax</a>
                                    <div>index.html 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/</div>
                                </li>
                                <li><a href="/article/3549.htm"
                                       title="BW / Universe Mappings" target="_blank">BW / Universe Mappings</a>
                                    <span class="text-muted">blueoxygen</span>
<a class="tag" taget="_blank" href="/search/BO/1.htm">BO</a>
                                    <div>      
BW Element    
OLAP Universe Element      
Cube  Dimension    
Class      
Charateristic    
A class with dimension and detail objects (Detail objects for key and desription)      
Hi</div>
                                </li>
                                <li><a href="/article/3676.htm"
                                       title="Java开发熟手该当心的11个错误" target="_blank">Java开发熟手该当心的11个错误</a>
                                    <span class="text-muted">tomcat_oracle</span>
<a class="tag" taget="_blank" href="/search/java/1.htm">java</a><a class="tag" taget="_blank" href="/search/%E5%A4%9A%E7%BA%BF%E7%A8%8B/1.htm">多线程</a><a class="tag" taget="_blank" href="/search/%E5%B7%A5%E4%BD%9C/1.htm">工作</a><a class="tag" taget="_blank" href="/search/%E5%8D%95%E5%85%83%E6%B5%8B%E8%AF%95/1.htm">单元测试</a>
                                    <div>#1、不在属性文件或XML文件中外化配置属性。比如,没有把批处理使用的线程数设置成可在属性文件中配置。你的批处理程序无论在DEV环境中,还是UAT(用户验收 
测试)环境中,都可以顺畅无阻地运行,但是一旦部署在PROD 上,把它作为多线程程序处理更大的数据集时,就会抛出IOException,原因可能是JDBC驱动版本不同,也可能是#2中讨论的问题。如果线程数目 可以在属性文件中配置,那么使它成为</div>
                                </li>
                                <li><a href="/article/3803.htm"
                                       title="推行国产操作系统的优劣" target="_blank">推行国产操作系统的优劣</a>
                                    <span class="text-muted">yananay</span>
<a class="tag" taget="_blank" href="/search/windows/1.htm">windows</a><a class="tag" taget="_blank" href="/search/linux/1.htm">linux</a><a class="tag" taget="_blank" href="/search/%E5%9B%BD%E4%BA%A7%E6%93%8D%E4%BD%9C%E7%B3%BB%E7%BB%9F/1.htm">国产操作系统</a>
                                    <div>最近刮起了一股风,就是去“国外货”。从应用程序开始,到基础的系统,数据库,现在已经刮到操作系统了。原因就是“棱镜计划”,使我们终于认识到了国外货的危害,开始重视起了信息安全。操作系统是计算机的灵魂。既然是灵魂,为了信息安全,那我们就自然要使用和推行国货。可是,一味地推行,是否就一定正确呢? 
 
先说说信息安全。其实从很早以来大家就在讨论信息安全。很多年以前,就据传某世界级的网络设备制造商生产的交</div>
                                </li>
                </ul>
            </div>
        </div>
    </div>

<div>
    <div class="container">
        <div class="indexes">
            <strong>按字母分类:</strong>
            <a href="/tags/A/1.htm" target="_blank">A</a><a href="/tags/B/1.htm" target="_blank">B</a><a href="/tags/C/1.htm" target="_blank">C</a><a
                href="/tags/D/1.htm" target="_blank">D</a><a href="/tags/E/1.htm" target="_blank">E</a><a href="/tags/F/1.htm" target="_blank">F</a><a
                href="/tags/G/1.htm" target="_blank">G</a><a href="/tags/H/1.htm" target="_blank">H</a><a href="/tags/I/1.htm" target="_blank">I</a><a
                href="/tags/J/1.htm" target="_blank">J</a><a href="/tags/K/1.htm" target="_blank">K</a><a href="/tags/L/1.htm" target="_blank">L</a><a
                href="/tags/M/1.htm" target="_blank">M</a><a href="/tags/N/1.htm" target="_blank">N</a><a href="/tags/O/1.htm" target="_blank">O</a><a
                href="/tags/P/1.htm" target="_blank">P</a><a href="/tags/Q/1.htm" target="_blank">Q</a><a href="/tags/R/1.htm" target="_blank">R</a><a
                href="/tags/S/1.htm" target="_blank">S</a><a href="/tags/T/1.htm" target="_blank">T</a><a href="/tags/U/1.htm" target="_blank">U</a><a
                href="/tags/V/1.htm" target="_blank">V</a><a href="/tags/W/1.htm" target="_blank">W</a><a href="/tags/X/1.htm" target="_blank">X</a><a
                href="/tags/Y/1.htm" target="_blank">Y</a><a href="/tags/Z/1.htm" target="_blank">Z</a><a href="/tags/0/1.htm" target="_blank">其他</a>
        </div>
    </div>
</div>
<footer id="footer" class="mb30 mt30">
    <div class="container">
        <div class="footBglm">
            <a target="_blank" href="/">首页</a> -
            <a target="_blank" href="/custom/about.htm">关于我们</a> -
            <a target="_blank" href="/search/Java/1.htm">站内搜索</a> -
            <a target="_blank" href="/sitemap.txt">Sitemap</a> -
            <a target="_blank" href="/custom/delete.htm">侵权投诉</a>
        </div>
        <div class="copyright">版权所有 IT知识库 CopyRight © 2000-2050 E-COM-NET.COM , All Rights Reserved.
<!--            <a href="https://beian.miit.gov.cn/" rel="nofollow" target="_blank">京ICP备09083238号</a><br>-->
        </div>
    </div>
</footer>
<!-- 代码高亮 -->
<script type="text/javascript" src="/static/syntaxhighlighter/scripts/shCore.js"></script>
<script type="text/javascript" src="/static/syntaxhighlighter/scripts/shLegacy.js"></script>
<script type="text/javascript" src="/static/syntaxhighlighter/scripts/shAutoloader.js"></script>
<link type="text/css" rel="stylesheet" href="/static/syntaxhighlighter/styles/shCoreDefault.css"/>
<script type="text/javascript" src="/static/syntaxhighlighter/src/my_start_1.js"></script>





</body>

</html>