Python高级编程(随书代码)

自动化脚本

G:\02.soft\$$python\py\pywinauto-0.4.0\pywinauto-0.4.0\docs\controls_overview.html

# modifier keys

MODIFIERS = {

'+': VK_SHIFT,

'^': VK_CONTROL,

'%': VK_MENU,

}

# 'codes' recognized as {CODE( repeat)?}

CODES = {

'BACK': 8,

'BACKSPACE':8,

'BKSP': 8,

'BREAK': 3,

'BS': 8,

'CAP': 20,

'CAPSLOCK': 20,

'DEL': 46,

'DELETE': 46,

'DOWN': 40,

'END': 35,

'ENTER': 13,

'ESC': 27,

'F1': 112,

'F2': 113,

'F3': 114,

'F4': 115,

'F5': 116,

'F6': 117,

'F7': 118,

'F8': 119,

'F9': 120,

'F10': 121,

'F11': 122,

'F12': 123,

'F13': 124,

'F14': 125,

'F15': 126,

'F16': 127,

'F17': 128,

'F18': 129,

'F19': 130,

'F20': 131,

'F21': 132,

'F22': 133,

'F23': 134,

'F24': 135,

'HELP': 47,

'HOME': 36,

'INS': 45,

'INSERT': 45,

'LEFT': 37,

'LWIN': 91,

'NUMLOCK': 144,

'PGDN': 34,

'PGUP': 33,

'PRTSC': 44,

'RIGHT': 39,

'RMENU': 165,

'RWIN': 92,

'SCROLLLOCK':145,

'SPACE': 32,

'TAB': 9,

'UP': 38,

'VK_ACCEPT': 30,

'VK_ADD': 107,

'VK_APPS': 93,

'VK_ATTN': 246,

'VK_BACK': 8,

'VK_CANCEL': 3,

'VK_CAPITAL': 20,

'VK_CLEAR': 12,

'VK_CONTROL': 17,

'VK_CONVERT': 28,

'VK_CRSEL': 247,

'VK_DECIMAL': 110,

'VK_DELETE': 46,

'VK_DIVIDE': 111,

'VK_DOWN': 40,

'VK_END': 35,

'VK_EREOF': 249,

'VK_ESCAPE': 27,

'VK_EXECUTE': 43,

'VK_EXSEL': 248,

'VK_F1': 112,

'VK_F2': 113,

'VK_F3': 114,

'VK_F4': 115,

'VK_F5': 116,

'VK_F6': 117,

'VK_F7': 118,

'VK_F8': 119,

'VK_F9': 120,

'VK_F10': 121,

'VK_F11': 122,

'VK_F12': 123,

'VK_F13': 124,

'VK_F14': 125,

'VK_F15': 126,

'VK_F16': 127,

'VK_F17': 128,

'VK_F18': 129,

'VK_F19': 130,

'VK_F20': 131,

'VK_F21': 132,

'VK_F22': 133,

'VK_F23': 134,

'VK_F24': 135,

'VK_FINAL': 24,

'VK_HANGEUL': 21,

'VK_HANGUL': 21,

'VK_HANJA': 25,

'VK_HELP': 47,

'VK_HOME': 36,

'VK_INSERT': 45,

'VK_JUNJA': 23,

'VK_KANA': 21,

'VK_KANJI': 25,

'VK_LBUTTON': 1,

'VK_LCONTROL':162,

'VK_LEFT': 37,

'VK_LMENU': 164,

'VK_LSHIFT': 160,

'VK_LWIN': 91,

'VK_MBUTTON': 4,

'VK_MENU': 18,

'VK_MODECHANGE': 31,

'VK_MULTIPLY': 106,

'VK_NEXT': 34,

'VK_NONAME': 252,

'VK_NONCONVERT': 29,

'VK_NUMLOCK': 144,

'VK_NUMPAD0': 96,

'VK_NUMPAD1': 97,

'VK_NUMPAD2': 98,

'VK_NUMPAD3': 99,

'VK_NUMPAD4': 100,

'VK_NUMPAD5': 101,

'VK_NUMPAD6': 102,

'VK_NUMPAD7': 103,

'VK_NUMPAD8': 104,

'VK_NUMPAD9': 105,

'VK_OEM_CLEAR': 254,

'VK_PA1': 253,

'VK_PAUSE': 19,

'VK_PLAY': 250,

'VK_PRINT': 42,

'VK_PRIOR': 33,

'VK_PROCESSKEY': 229,

'VK_RBUTTON': 2,

'VK_RCONTROL': 163,

'VK_RETURN': 13,

'VK_RIGHT': 39,

'VK_RMENU': 165,

'VK_RSHIFT': 161,

'VK_RWIN': 92,

'VK_SCROLL': 145,

'VK_SELECT': 41,

'VK_SEPARATOR': 108,

'VK_SHIFT': 16,

'VK_SNAPSHOT': 44,

'VK_SPACE': 32,

'VK_SUBTRACT': 109,

'VK_TAB': 9,

'VK_UP': 38,

'ZOOM': 251,

}

charmap

==============================Control Identifiers:

CharGridWClass - '' (L802, T101, R1285, B434)

'CharGridWClass' '字体(&F):CharGridWClass'

Static - '复制字符(&A):' (L781, T455, R919, B474)

'Static' 'Static0' 'Static1' '复制字符(&A):' '复制字符(&A):Static'

RICHEDIT50W - '' (L927, T449, R1120, B483)

'RICHEDIT50W' '复制字符(&A):RICHEDIT50W'

Button - '选择(&S)' (L1126, T449, R1214, B479)

'Button' 'Button0' 'Button1' '选择(&S)' '选择(&S)Button'

Button - '复制(&C)' (L1221, T449, R1309, B479)

'Button2' '复制(&C)' '复制(&C)Button'

Button - '高级查看(&V)' (L781, T485, R893, B511)

'CheckBox' '高级查看(&V)' '高级查看(&V)CheckBox'

Static - '字符集(&T):' (L781, T530, R926, B549)

'Static2' '字符集(&T):' '字符集(&T):Static'

ComboBox - 'Windows: 简体中文' (L927, T523, R1163, B548)

'ComboBox' 'ComboBox0' 'ComboBox1' '字符集(&T):ComboBox'

Static - '转到 Unicode(&U):' (L1168, T532, R1256, B570)

'Static3' '转到 Unicode(&U):' '转到 Unicode(&U):Static'

Edit - '' (L1263, T523, R1307, B553)

'Edit' 'Edit0' 'Edit1' '转到 Unicode(&U):Edit'

Static - '分组依据(&G):' (L781, T568, R926, B587)

'Static4' '分组依据(&G):' '分组依据(&G):Static'

ComboBox - '全部' (L927, T561, R1162, B586)

'ComboBox2' '分组依据(&G):ComboBox'

Static - '搜索(&E):' (L781, T608, R926, B627)

'Static5' '搜索(&E):' '搜索(&E):Static'

Edit - '' (L927, T600, R1165, B630)

'Edit2' '搜索(&E):Edit'

Button - '搜索(&R)' (L1182, T600, R1270, B630)

'Button3' '搜索(&R)' '搜索(&R)Button'

Static - '字体(&F):' (L781, T64, R842, B83)

'Static6' '字体(&F):' '字体(&F):Static'

ComboBox - 'TOPhonetic' (L843, T58, R1218, B81)

'ComboBox3' '字体(&F):ComboBox'

Button - '帮助(&H)' (L1224, T58, R1312, B88)

'Button4' '帮助(&H)' '帮助(&H)Button'

==============================Control Identifiers:

CharGridWClass - '' (L802, T101, R1285, B434)

'CharGridWClass' '字体(&F):CharGridWClass'

Static - '复制字符(&A):' (L781, T455, R919, B474)

'Static' 'Static0' 'Static1' '复制字符(&A):' '复制字符(&A):Static'

RICHEDIT50W - '' (L927, T449, R1120, B483)

'RICHEDIT50W' '复制字符(&A):RICHEDIT50W'

Button - '选择(&S)' (L1126, T449, R1214, B479)

'Button' 'Button0' 'Button1' '选择(&S)' '选择(&S)Button'

Button - '复制(&C)' (L1221, T449, R1309, B479)

'Button2' '复制(&C)' '复制(&C)Button'

Button - '高级查看(&V)' (L781, T485, R893, B511)

'CheckBox' '高级查看(&V)' '高级查看(&V)CheckBox'

Static - '字符集(&T):' (L781, T530, R926, B549)

'Static2' '字符集(&T):' '字符集(&T):Static'

ComboBox - 'Windows: 简体中文' (L927, T523, R1163, B548)

'ComboBox' 'ComboBox0' 'ComboBox1' '字符集(&T):ComboBox'

Static - '转到 Unicode(&U):' (L1168, T532, R1256, B570)

'Static3' '转到 Unicode(&U):' '转到 Unicode(&U):Static'

Edit - '' (L1263, T523, R1307, B553)

'Edit' 'Edit0' 'Edit1' '转到 Unicode(&U):Edit'

Static - '分组依据(&G):' (L781, T568, R926, B587)

'Static4' '分组依据(&G):' '分组依据(&G):Static'

ComboBox - '全部' (L927, T561, R1162, B586)

'ComboBox2' '分组依据(&G):ComboBox'

Static - '搜索(&E):' (L781, T608, R926, B627)

'Static5' '搜索(&E):' '搜索(&E):Static'

Edit - '' (L927, T600, R1165, B630)

'Edit2' '搜索(&E):Edit'

Button - '搜索(&R)' (L1182, T600, R1270, B630)

'Button3' '搜索(&R)' '搜索(&R)Button'

Static - '字体(&F):' (L781, T64, R842, B83)

'Static6' '字体(&F):' '字体(&F):Static'

ComboBox - 'TOPhonetic' (L843, T58, R1218, B81)

'ComboBox3' '字体(&F):ComboBox'

Button - '帮助(&H)' (L1224, T58, R1312, B88)

'Button4' '帮助(&H)' '帮助(&H)Button'

## pytesser是一个用于图片文本识别的python模块,即从文本的截图中还原出文本信息

>>> from pytesser import *

>>> image = Image.open('fnord.tif') # Open image object using PIL

>>> print image_to_string(image) # Run tesseract.exe on image

fnord

>>> print image_file_to_string('fnord.tif')

fnord

try:

import Image

except ImportError:

from PIL import Image

import pytesseract

print(pytesseract.image_to_string(Image.open('test.png')))

print(pytesseract.image_to_string(Image.open('test-european.jpg'), lang='fra'))

### py-ocr

import Image

import sys

from pyocr import pyocr

tools = pyocr.get_available_tools()[:]

if len(tools) == 0:

print("No OCR tool found")

sys.exit(1)

print("Using '%s'" % (tools[0].get_name()))

tools[0].image_to_string(Image.open('test.png'), lang='fra',

builder=TextBuilder())

### py-ocr from PIL import Image

import sys

import pyocr

import pyocr.builders

tools = pyocr.get_available_tools()

if len(tools) == 0:

print("No OCR tool found")

sys.exit(1)

tool = tools[0]

print("Will use tool '%s'" % (tool.get_name()))

# Ex: Will use tool 'tesseract'

langs = tool.get_available_languages()

print("Available languages: %s" % ", ".join(langs))

lang = langs[0]

print("Will use lang '%s'" % (lang))

# Ex: Will use lang 'fra'

txt = tool.image_to_string(Image.open('test.png'),

lang=lang,

builder=pyocr.builders.TextBuilder())

word_boxes = tool.image_to_string(Image.open('test.png'),

lang=lang,

builder=pyocr.builders.WordBoxBuilder())

line_and_word_boxes = tool.image_to_string(

Image.open('test.png'), lang=lang,

builder=pyocr.builders.LineBoxBuilder())

# Digits - Only Tesseract

digits = tool.image_to_string(Image.open('test-digits.png'),

lang=lang,

builder=pyocr.tesseract.DigitBuilder())

PyTesser 官方下载地址:http://code.google.com/p/pytesser/downloads/list

Prerequisites:

Python-tesseract requires python 2.5 or later or python 3.

You will need the Python Imaging Library (PIL). Under Debian/Ubuntu, this is the package "python-imaging" or "python3-imaging" for python3.

Install google tesseract-ocr from http://code.google.com/p/tesseract-ocr/ . You must be able to invoke the tesseract command as "tesseract". If this isn't the case, for example because tesseract isn't in your PATH, you will have to change the "tesseract_cmd" variable at the top of 'tesseract.py'. Under Debian/Ubuntu you can use the package "tesseract-ocr".

## SourceForge、GitHub、Bitbucket、CodePlex

## SyntaxHighlighter

version 3.0.9 (Mon, 14 Jul 2014 13:04:28 GMT)

JavaScript code syntax highlighter.

Copyright 2004-2013 Alex Gorbatchev.

### 写入

wb = Workbook()

ws = wb.add_sheet('result')

ws.write(0,0,“hello”)

wb.save('result.xls')

### 读

from pyExcelerator import *

sheets = parse_xls('d:/a.xls')

# eclipse字体设置

在Eclipse环境建立新的workspace目录时,workspace目录下会自动生成.metadata目录,其中保存Eclipse关于这个工作区的相关配置,历史记录等等数据

只好先修改配置文件:

工作区/.metadata/.plugins/org.eclipse.core.runtime/.settings/org.eclipse.ui.workbench.prefs 文件

org.eclipse.jface.textfont=1|Courier New|12.0|0|WINDOWS|1|-16|0|0|0|400|0|0|0|0|3|2|1|49|Courier New;改为

org.eclipse.jface.textfont=1|Courier New|14.0|0|WINDOWS|1|-16|0|0|0|400|0|0|0|0|3|2|1|49|Courier New;把字号由12改为14号

需要重启eclipse才生效

# eclim

Eclipse Luna SR2 (4.4.2) Release for Windows

E:\Vim\vimfiles

G:\02-greenTools\eclipse_4.4.2

# 请问如何查询COM接口里面的成员(属性,方法等等)

GetIDsOfNames.

OLE View

## Windows Registry Editor Version 5.00

[HKEY_CLASSES_ROOT\Word.Application]

@="Microsoft Word Application"

[HKEY_CLASSES_ROOT\Word.Application\CLSID]

@="{000209FF-0000-0000-C000-000000000046}"

[HKEY_CLASSES_ROOT\Word.Application\CurVer]

@="Word.Application.12"

#@ 如何在ole view中看到Word.Application的信息, 这个节点在哪里?

## Error Messages for Windows

## CTRL+D ECLIPSE

## pycom32

### PyObject(Common Object Structures)

All object types are extensions of this type. This is a type which contains the information Python needs to treat a pointer to an object as an object. In a normal “release” build, it contains only the object’s reference count and a pointer to the corresponding type object. It corresponds to the fields defined by the expansion of the PyObject_HEAD macro.

### PyIBase

class PYCOM_EXPORT PyIBase :

public PyObject

{

public:

// virtuals for Python support

virtual PyObject *getattr(char *name);

virtual int setattr(char *name, PyObject *v);

virtual PyObject *repr();

virtual int compare(PyObject *other) {

if (this == other)

return 0;

if (this < other)

return -1;

return 1;

}

// These iter are a little special, in that returning NULL means

// use the implementation in the type

virtual PyObject *iter() {return NULL;}

virtual PyObject *iternext() {return NULL;}

protected:

PyIBase();

virtual ~PyIBase();

public:

static BOOL is_object(PyObject *, PyComTypeObject *which);

BOOL is_object(PyComTypeObject *which);

static void dealloc(PyObject *ob);

static PyObject *repr(PyObject *ob);

static PyObject *getattro(PyObject *self, PyObject *name);

static int setattro(PyObject *op, PyObject *obname, PyObject *v);

static int cmp(PyObject *ob1, PyObject *ob2);

static PyObject *richcmp(PyObject *ob1, PyObject *ob2, int op);

};

### PyIUnknown

class PYCOM_EXPORT PyIUnknown : public PyIBase

{

public:

MAKE_PYCOM_CTOR(PyIUnknown);

virtual PyObject *repr();

virtual int compare(PyObject *other);

static IUnknown *GetI(PyObject *self);

IUnknown *m_obj;

static char *szErrMsgObjectReleased;

static void SafeRelease(PyIUnknown *ob);

static PyComTypeObject type;

// The Python methods

static PyObject *QueryInterface(PyObject *self, PyObject *args);

static PyObject *SafeRelease(PyObject *self, PyObject *args);

protected:

PyIUnknown(IUnknown *punk);

~PyIUnknown();

}

### PyIDispatch

class PYCOM_EXPORT PyIDispatch : public PyIUnknown

{

public:

MAKE_PYCOM_CTOR(PyIDispatch);

static IDispatch *GetI(PyObject *self);

static PyComTypeObject type;

// The Python methods

static PyObject *Invoke(PyObject *self, PyObject *args);

static PyObject *InvokeTypes(PyObject *self, PyObject *args);

static PyObject *GetIDsOfNames(PyObject *self, PyObject *args);

static PyObject *GetTypeInfo(PyObject *self, PyObject *args);

static PyObject *GetTypeInfoCount(PyObject *self, PyObject *args);

protected:

PyIDispatch(IUnknown *pdisp);

~PyIDispatch();

};

##

from win32com.client import Dispatch, constants

from win32com.client.gencache import EnsureDispatch

EnsureDispatch('Word.Application') #makepy 导入Word类库,否则constants无法使用

msword = Dispatch('Word.Application')

msword.Visible = True #是否可见

msword.DisplayAlerts = 0

doc = msword.Documents.Open(FileName = strDir + r'tbbts01e01.docx') #打开已有文件

newdoc = msword.Documents.Add() #添加新文件

newdoc.SaveAs(‘new.docx') #另存为

###

在使用win32com 之前,需要导入指定的类库(Makepy), 方法:

There are a couple of different ways to run makepy.

Start Pythonwin, and from the menu select Tools->Com Makepy Utility. You should see a list

of registered typelibs. Select "Microsoft Word x.y Object Library" and hit Ok.

This can also be done programatically by initiating Word with

win32com.client.gencache.EnsureDispatch('Word.Application')

from docximport Document

from docx.sharedimport Inches

document= Document()

document.add_heading('Document Title',0)

p= document.add_paragraph('A plain paragraph having some ')

p.add_run('bold').bold= True

p.add_run(' and some ')

p.add_run('italic.').italic= True

document.add_heading('Heading, level 1', level=1)

document.add_paragraph('Intense quote', style='IntenseQuote')

document.add_paragraph(

'first item in unordered list', style='ListBullet'

)

document.add_paragraph(

'first item in ordered list', style='ListNumber'

)

document.add_picture('monty-truth.png', width=Inches(1.25))

table= document.add_table(rows=1, cols=3)

hdr_cells= table.rows[0].cells

hdr_cells[0].text= 'Qty'

hdr_cells[1].text= 'Id'

hdr_cells[2].text= 'Desc'

for itemin recordset:

row_cells= table.add_row().cells

row_cells[0].text= str(item.qty)

row_cells[1].text= str(item.id)

row_cells[2].text= item.desc

document.add_page_break()

document.save('demo.docx')

一、给Eclipse安装SVN,最常见的有两种方式:手动方式和使用安装向导方式。具体步骤如下:

方式一:手动安装

1、从官网下载site-1.6.9.zip文件,网址是:subclipse.tigris.org

2、从中解压出features与plugins文件夹,复制到E:/MyEclipse/myPlugin/svn里面,其它的*.xml文件不要。

3、在E:/MyEclipse/MyEclipse X.X/dropins下新建文件svn.link,内容是:path=E://MyEclipse//myPlugin//svn 保存。

4、删除E:/MyEclipse/MyEclipse X.X/configuration/org.eclipse.update文件夹

5、重启myeclipse就一切正常了。

方式二:使用Eclipse安装向导

打开Eclipse

help->Software Updates->find and install(如果没有这个就用help->Software Updates->Add/Remove Software即可)

选择search for new features to install, Next

点击new remote site

输入name:subclipse 1.6.x,url:http://subclipse.tigris.org/update_1.6.x,点OK

或者:

Name: Subclipse 1.6.x (Eclipse 3.2+) URL: http://subclipse.tigris.org/update_1.6.x

Name: Subclipse 1.4.x (Eclipse 3.2+) URL: http://subclipse.tigris.org/update_1.4.x

Name: Subclipse 1.2.x (Eclipse 3.2+) URL: http://subclipse.tigris.org/update_1.2.x

Name: Subclipse 1.0.x (Eclipse 3.0/3.1) URL: http://subclipse.tigris.org/update_1.0.x

选中subclipse,点击finish

一直NEXT,这里注意下,有些时候会出现 Subclipse Integration for Mylyn 3.x (Optional) (3.0.0) requires plug-in "org.eclipse.mylyn.tasks.core (3.0.0)", or compatible.错误,这个不要紧,在弹出框中选择subclipse,把Subclipse Integration for Mylyn 3.x选项去掉即可

Next一路安装完成!

二、Eclipse中使用SVN(以MyEclipse8.0为例)

1、共享项目(把本地的项目共享到subversion服务器上)

打开MyEclipse8.0,假设要共享projTest是项目名称

右键项目projTest->Team->Share Project->Svn,

单库模式下url填写svn://svn server address/,多库模式下url填写svn://svn server address/Repository1,其中Repository1是库的名称

next直到finish,proj1就被共享到svn服务器上了,但是代码并没上传,还需要commit一次

右键项目projTest,team->commit,项目内容就被上传到svn服务器了

2、签出项目(把svn服务器上的项目下载的到本地)

打开MyEclipse8.0

window->open perspective->svn repository explorer(如果没有在other里选择)

在左边空白处右键->new->repository location

单库模式下url填写svn://svnserveraddress/,多库模式下url填写svn://svnserveraddress/Repository1(同步骤二)

右键projTest->check out

next直到finish,该项目就被签出到本地,切换到java视图就能看到该项目了

python自动测试g_python自动化测试windows gui相关推荐

  1. python自动测试g_Python自动化测试如何自动生成测试用例?

    原文作者:陈安妮annie1 原出处:简书 上文内容不用于商业目的,如涉及知识产权问题,请权利人联系博为峰,我们将立即处理.传统的测试用例需要测试或者开发人员将用户的操作用代码表示出来,通过断言判断是 ...

  2. python自动测试p-Python自动化测试

    什么是自动化测试? 自动化测试,一般是指软件测试的自动化.自动化测试是把以人为驱动的测试转化为机器执行的一种过程.实际上自动化测试就是用自动化测试工具代替手工测试,即是模拟手工测试,从而利用所写脚本执 ...

  3. python自动测试p-python自动化测试_6

    接口测试: uuittest 模块: unittest模块的测试用例,属于自动化的门槛,进去了基本算自动化入了门,测试内容很简单,模拟给url推送用户名.密码测试登录功能 登录: #login_tes ...

  4. python自动测试p-python 自动化测试 pytest 的使用

    pytest 是一款以python为开发语言的第三方测试,主要特点如下: 比自带的 unittest 更简洁高效,兼容 unittest框架 支持参数化 可以更精确的控制要测试的测试用例 丰富的插件, ...

  5. python自动测试m_python自动化测试实例解析

    本文实例讲述了python自动化测试的过程,分享给大家供大家参考. 具体代码如下: import unittest ########################################## ...

  6. python自动测试p-python自动化测试_8

    接口测试: md5 加密: import hashlib # 待加密信息 str = 'asdas89799,.//plrmf' # 创建md5对象 hl = hashlib.md5() # Tips ...

  7. python自动测试g_python自动化测试报告(excel篇)

    转:https://www.jianshu.com/p/6c5d328bf390 # -*- coding: utf-8 -*- import xlsxwriter def get_format(wd ...

  8. python自动测试u_自动化测试——Selenium+Python之下拉菜单的定位

    1.通过selenium.webdriver.support.ui的Select进行定位 下拉菜单如下图: 定位代码(选择Male): from selenium.webdriver.support. ...

  9. python自动测试ping IP

    python自动测试ping IP,将不通的IP保存到txt中. # -*- coding: utf-8 -*- # @Time : 2023/3/6 9:14 # @Author : JulyLi ...

最新文章

  1. 《中国人工智能学会通讯》——4.27 电子数据取证理论与技术
  2. 三、入门实例----基于注解
  3. 「Python-Bug」matplotlib画图时报错Process finished with exit code 139 (interrupted by signal 11: SIGSEGV)
  4. 疯狂了!当游戏爱上MongoDB会怎么样???
  5. javascript动态创建table
  6. CVE-2013-3897漏洞成因与利用分析
  7. 请写出sfr和sbit的语句格式_习题_C51语言答案
  8. 谈谈神经网络的大规模训练优化
  9. 云小课 | DSC:快速识别敏感数据并脱敏
  10. Zabbix安装记录
  11. powerpc如何移植Linux系统,PowerPC平台 u-boot 移栽
  12. 免费的ERP软件哪一款好用?这3款让综合管理更高效
  13. linux bridge - mac和vlan转发
  14. 迷你游戏平台开发(二)
  15. 性能测试监控TP50、TP99、TP999含义
  16. oracle监听启动失败12560,Oracle监听器无法启动(TNS-12555,TNS-12560,TNS-00525)
  17. 网上出售企业支付宝骗局,不看后悔
  18. 用python绘制高光谱图像的光谱曲线图
  19. 系统日志Logrotate配置
  20. 对于共享电脑的到来,您有什么想说的

热门文章

  1. 新思路二级c语言程序,新思路等考通二级C
  2. html历史查看器,网页源代码查看器
  3. Android系统学习(37)---Android知识点及资料汇总
  4. 什么叫做CHINANET?
  5. 哪些情形是围标串标?电子化招投标系统怎么避免围标串标?
  6. 华为、字节等大厂都在用的PDCA高效工作模型,8张图给你讲清楚!
  7. 视觉SLAM十四讲——对极约束(2D-2D)笔记
  8. 有关SEO效果评估的七大指标你知道吗?
  9. jackson jdk版本对应关系_Jackson:10分钟弄明白Jackson
  10. 跳过Windows安装程序