http://sourceforge.net/projects/pywinauto/files/pywinauto/

http://www.microsoft.com/en-us/download/confirmation.aspx?id=44266

https://pypi.python.org/pypi/SendKeys/

http://files.cnblogs.com/files/zhang-pengcheng/SendKeys-0.3.zip

Python高级编程(随书代码)

http://files.cnblogs.com/files/zhang-pengcheng/Python%E9%AB%98%E7%BA%A7%E7%BC%96%E7%A8%8B%EF%BC%88%E9%9A%8F%E4%B9%A6%E4%BB%A3%E7%A0%81%EF%BC%89.zip

自动化脚本

http://blog.csdn.net/xinpo66/article/details/9034473

http://blog.csdn.net/xinpo66/article/details/9034507

http://nullege.com/codes/search/pywinauto.application.Application.Notepad.Edit.TypeKeys

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

PIL库资源地址: http://www.pythonware.com/products/pil/

http://www.oschina.net/p/pyocr

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)

http://alexgorbatchev.com/SyntaxHighlighter

JavaScript code syntax highlighter.

Copyright 2004-2013 Alex Gorbatchev.

 

## 使用pyExcelerator来读写 Excel文件(详细)

### 写入

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

http://www.gregorybraun.com/MSWinErr.html

 

 

## CTRL+D ECLIPSE

zen_actions.match_pair_outward - Nullege Python Samples

 

## COM三大接口:IUnknown、IClassFactory、IDispatch。

http://www.cnblogs.com/weiqubo/archive/2011/03/18/1988033.html

 

 

## C++调Python示例

http://www.cnblogs.com/Hisin/archive/2012/02/27/2370590.html

 

## 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();

};

 

##

转自: http://blog.csdn.net/ccbird88/article/details/6193769

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')

## 转自http://hao.jobbole.com/python-docx/

from docx import Document

from docx.shared import 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 item in 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')

老github主页:https://github.com/mikemaccana/python-docx

新github主页:https://github.com/python-openxml/python-docx

## eclipse svn

转自: http://blog.csdn.net/vebasan/article/details/6186344

一、给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视图就能看到该项目了

### http://subclipse.tigris.org/files/documents/906/49280/site-1.8.22.zip

python自动化测试windows gui的更多相关文章

  1. 开源自己用python封装的一个Windows GUI(UI Automation)自动化工具,支持MFC,Windows Forms,WPF,Metro,Qt

    首先,大家可以看下这个链接 Windows GUI自动化测试技术的比较和展望 . 这篇文章介绍了Windows中GUI自动化的三种技术:Windows API, MSAA - Microsoft Ac ...

  2. AutoIt操作Windows GUI实现文件上传

    AutoIt 一个使用类似BASIC脚本语言的免费软件,用于Windows GUI(图形用户界面)中进行自动化操作.它利用模拟键盘按键,鼠标移动和窗口/控件的组合来实现自动化任务. 官方网站: htt ...

  3. python自动化测试框架学习

    今天发现python有多个框架可以用于自动化测试方面,下面整理了下splinter和urllib2框架,对于pywinauto框架和ruby框架先记录下以后需要用到再学习. python有个splin ...

  4. 《Python自动化测试九章经》

    Python是当前非常流行的一门编程语言,它除了在人工智能.数据处理.Web开发.网络爬虫等领域得到广泛使用之外,他也非常适合软件测试人员使用,但是,对于刚入行的测试小白来说,并不知道学习Python ...

  5. python自动化测试(2)-自动化基本技术原理

    python自动化测试(2) 自动化基本技术原理 1   概述 在之前的文章里面提到过:做自动化的首要本领就是要会 透过现象看本质 ,落实到实际的IT工作中就是 透过界面看数据. 掌握上面的这样的本领 ...

  6. 用 eric6 与 PyQt5 实现python的极速GUI编程(系列01)--Hello world!

    [题记] 我是一个菜鸟,这个系列是我的学习笔记. PyQt5 出来有一段时间了, PyQt5 较之 PyQt4 有一些变化,而网上流传的几乎都是 PyQt4 的教程,照搬的话大多会出错. eric6 ...

  7. selenium + python 自动化测试环境搭建

    selenium + python 自动化测试 —— 环境搭建 关于 selenium Selenium 是一个用于Web应用程序测试的工具.Selenium测试直接运行在浏览器中,就像真正的用户在操 ...

  8. Python自动化测试 -ConfigParser模块读写配置文件

    C#之所以容易让人感兴趣,是因为安装完Visual Studio, 就可以很简单的直接写程序了,不需要做如何配置. 对新手来说,这是非常好的“初体验”, 会激发初学者的自信和兴趣. 而有些语言的开发环 ...

  9. selenium2 python自动化测试实战(回归测试)

    selenium2 python自动化测试实战 最近接手商城的项目,针对后台测试,功能比较简单,但是流程比较繁多,涉及到前后台的交叉测试.在对整个项目进行第一轮测试完成之后,考虑以后回归测试任务比较重 ...

随机推荐

  1. 残留的linux相关笔记

    1. 设置网络环境1) 设置宿主机网络环境#ifconfig eth1 192.168.16.111 2) 设置开发板网络环境>pri>setenv ipaddr 192.168.16.2 ...

  2. NOIP PJ游记

    Day -1 感觉自信满满,一等奖应该稳了,毕竟初一时我这么菜都拿了二等奖,然后就睡觉了... Day 1 在大巴上玩元气骑士可开心了,车上欢欢喜喜,到了考场,一眼看题,以为很简单. T1硬模拟... ...

  3. [Codeforces86D]Powerful array(莫队算法)

    题意:定义K[x]为元素x在区间[l,r]内出现的次数,那么它的贡献为K[x]*K[x]*x 给定一个序列,以及一些区间询问,求每个区间的贡献 算是莫队算法膜版题,不带修改的 Code #includ ...

  4. P2341 [HAOI2006]受欢迎的牛(tarjan+缩点)

    P2341 [HAOI2006]受欢迎的牛 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶 牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的“喜欢”是可以传递的 ...

  5. Apache Spark 2.2.0 中文文档

    Apache Spark 2.2.0 中文文档 - 快速入门 | ApacheCN Geekhoo 关注 2017.09.20 13:55* 字数 2062 阅读 13评论 0喜欢 1 快速入门 使用 ...

  6. Android字体大小怎么自适应不同分辨率?

    今天有人问我,android系统不同分辨率,不同大小的手机,字体大小怎么去适应呢?其实字体的适应和图片的适应是一个道理的. 一. 原理如下: 假设需要适应320x240,480x320分辨率.在res ...

  7. 使用Unity做项目的时候,一些好的建议

    内容来自这个网站http://devmag.org.za/2012/07/12/50-tips-for-working-with-unity-best-practices/ ,我选取了目前我看得懂的一 ...

  8. 《Cracking the Coding Interview》——第18章:难题——题目4

    2014-04-29 01:05 题目:数数从0到n总共有多少个数字‘2’? 解法:数位动态规划,可以O(log10(n))时间内解决. 代码: // 18.4 Count the number of ...

  9. 《数据结构》C++代码 前言

    现在大二正在上<数据结构>课,课内的书上代码实现很喜欢无脑用类.变量名字很长,而且常常实现太繁琐,并且代码有些无法运行,这些对于老手无所谓,但初学者看起来却会很不舒服.因此写点自己实现这些 ...

  10. C编译器MinGW安装、下载及在notepad++中运行C程序

    一.C编译器MinGW的下载及安装步骤 打开MinGW官网:http://www.mingw.org/ 图一 图二 图三 图四 图五 图六 系统中配置环境变量: 图七 验证是否安装成功: CMD中运行 ...