精华内容
下载资源
问答
  • 在写某个平台的自动化脚本时,笔者把全部的操作都封装到了两个类中,page.py和commonpage.py:page.py部分代码:classBasePage(object):'''页面基础类'''def __init__(self, driver):self.driver=driverdeffind_...

    在写某个平台的自动化脚本时,笔者把全部的操作都封装到了两个类中,page.py和commonpage.py:

    page.py部分代码:classBasePage(object):'''页面基础类'''

    def __init__(self, driver):self.driver=driverdeffind_element(self,loc):return self.driver.find_element(*loc)#在输入框中输入文字

    definput_text(self,loc,text):

    self.find_element(loc).send_keys(text)

    commonpage.py部分代码:classCommonPage(BasePage):'''平台通用的功能'''

    ####################################

    #点击菜单

    #big:第几个大菜单

    #small:第几个小菜单

    defclick_menu(self,big):

    big_menu= (By.XPATH,"//ul/li[%s]/a/span"%big)

    self.click(big_menu)

    sleep(2)defclick_small_menu(self,small,list):

    small_menu= (By.XPATH,"//ul/li[%s]/ul/li[2]"%small)

    self.click(small_menu)

    sleep(2)

    页面的操作只要调用这两个类(大部分其实在调用commonpage类),几乎能完成全部元素的封装、简化操作流程等。类似封装页面元素部分代码:

    from pages.page importBasePagefrom pages importcommonpage,loginpage#活动编辑-报名表界面

    classact_applyPage(BasePage):#点击菜单

    defgoto_activity_page(self):

    loginpage.LoginPage(self.driver).login_sys(username="abcd", passwd="password")

    com_page=commonpage.CommonPage(self.driver)

    com_page.click_menu(2,1)#点击某个tab

    defclick_act_apply_tab(self):print u"点击 act_apply_tab"compage=commonpage.CommonPage(self.driver)

    compage.click_tab(5)

    能看出封装页面元素的代码很多都是类似的,只是参数不同。这就引发了笔者的思考:“能不能快捷生成代码?”

    上网搜索资料,大多都是使用Templat类,研究后发现达不到笔者想要结果(也有可能笔者还没掌握Templat类的使用,T-T)。

    最近刚好总结了python处理配置文件的知识,想到可以用在自动生成代码这里。

    大致思路是:section值可作为类名,option值可作为方法,在value中,用“,”隔开多个有用的参数,其中第一个参数是option的类型(这个类型决定用那一段代码);

    先遍历sections,在每个section下,遍历{option:value}键,分析value中的类型,把对应的代码写到文件中。

    先来看看配置文件:

    #活动#section

    [activity,frmActivityEdit]#{option:value}

    start_part:start,活动编辑,

    activity:menu,2,1add_button:addbtn,4,

    下面是生成脚本的部分代码:

    importConfigParserimporttime

    conf=ConfigParser.RawConfigParser()

    #读取配置文件

    conf.read("section1.cfg")

    now= time.strftime("%Y-%m-%d",time.localtime(time.time()))

    sectionlist=conf.sections()#print sectionlist

    for list insectionlist:

    (classname,frmedit)= list.split(',')#生成文件

    pyfilepath = r'E:\\workspace\\%spage.py'%classname#写文件

    pyfile = open(pyfilepath,'w')#读取每个section,遍历键,分析类型,写入代码

    optionlist =conf.options(list)for list2 inoptionlist:

    #分解value

    (optiontype,ranking,selector)= conf.get(list, list2).split(',')

    #需要生成的脚本

    menu_code= '''\n\n def goto_%s_page(self):

    loginpage.LoginPage(self.driver).login_sys(username="abcd", passwd="password")

    com_page = commonpage.CommonPage(self.driver)

    com_page.click_menu(%s,%s)'''%(list2,ranking,selector)

    #判断类型,决定写入哪些脚本if optiontype == 'start':

    pyfile.writelines(start_code)elif optiontype == 'menu':

    pyfile.writelines(menu_code)

    else:...

    pyfile.close()

    接下来只要完善配置文件,大部分的界面类就能完成了。

    持续学习中,,,

    展开全文
  • 不同数据测试形成多条测试用例,如果复制的话 会让代码很冗长,并且并不好维护,现在封装的方法把 不变的代码 和 变化的参数 分别封装,形成动态 生成测试用例 ,主要用到 python中 setattr()重新定义属性的...

    1.对于一种对同一个页面同一点 要用不同数据测试形成多条测试用例,如果复制的话 会让代码很冗长,并且并不好维护,现在用封装的方法把 不变的代码 和 变化的参数 分别封装,形成动态 生成测试用例 ,主要用到 python中 setattr()重新定义属性的方法实现 ,具体原理为:如果该对象中没有这种属性,会自动加上这个属性,如果存在,则忽略

    好了 上代码:

     

    # conding=utf-8
    from appium import webdriver
    import time
    import sys
    import re
    import HTMLTestRunner
    import unittest
    import xlrd  #excel驱动程序
    from test import test_support
    from xlrd import open_workbook
    
    
    class Login(unittest.TestCase):
        def setUp(self):
            pass
    
        def clear(self):
            pass
    
        desired_caps = {
            'platformName': 'Android',
            'deviceName': 'FA56GB105163',
            'platformVersion': '5.0.2',
            'appPackage': 'com.zhonghong.www.qianjinsuo',
            'appActivity': 'com.zhonghong.www.qianjinsuo.main.activity.qjsMian.main.LoadingActivity',
            'unicodeKeyboard': True,  # 使用unicodeKeyboard的编码方式来发送字符串 ,可以实现输入中文
            'resetKeyboard': True  # 隐藏虚拟键盘,防止遮挡元素
        }
        driver = webdriver.Remote('http://127.0.0.1:4723/wd/hub', desired_caps)
        # 休眠15s等待程序启动
        time.sleep(2)
        driver.find_element_by_id("com.zhonghong.www.qianjinsuo:id/rb_zhiye_service").click()
        print("aaaaaaa")
    
        def getTest(self, arg1, arg2, arg3, arg4):  # 定义的函数,最终生成的测试用例的执行方法
            if arg1 =='': #判断是否为空
               asx=arg1
            else:asx=int(arg1)
            add=int(arg2)
            eee=arg3
            print(asx)
    
            self.driver.find_element_by_id("com.zhonghong.www.qianjinsuo:id/textfield_et_phone_num").clear()
            self.driver.find_element_by_id("com.zhonghong.www.qianjinsuo:id/textfield_et_phone_num").send_keys(asx)
            self.driver.find_element_by_id("com.zhonghong.www.qianjinsuo:id/textfield_et_pass").clear()
            self.driver.find_element_by_id("com.zhonghong.www.qianjinsuo:id/textfield_et_pass").send_keys(add)
            self.driver.find_element_by_id("com.zhonghong.www.qianjinsuo:id/login").click()
            time.sleep(1)
            ee = self.driver.find_elements_by_id("com.zhonghong.www.qianjinsuo:id/tv_error_text")
            self.assertEqual(eee, ee[0].text)
    
        @staticmethod
        def getTestFunc(arg1, arg2, arg3, arg4):
            def func(self):
                self.getTest(arg1, arg2, arg3, arg4)
    
            return func
    
    
    def __generateTestCases():
        data = open_workbook('D:\\test.xls')  # 打开文件
        table = data.sheet_by_index(0)  # 遍历所有数据
    # datas = table.row_values(0) # 获取整列数据 nrows
    = table.nrows #获得行数 list = [] for i in range(1, nrows): #忽略表头 ,开始遍历 datas = table.row_values(i) #获得每行的数据 list.append(datas) #加载到list中 print(list) for args in list: print(args) setattr(Login, 'test_func_%s' % args[3], Login.getTestFunc(*args)) # 通过setattr自动为TestCase类添加成员方法,方法以“test_func_”开头 __generateTestCases() if __name__ == '__main__': suite = unittest.TestSuite() suite.addTest(Login('test_func_smillphoone')) suite.addTest(Login('test_func_longphone')) suite.addTest(Login('test_func_nullphone')) timestr = time.strftime('%Y%m%d%H%M%S',time.localtime(time.time())) filename = "D:\\result_" + timestr + ".html" print (filename) fp = open(filename, 'wb') runner = HTMLTestRunner.HTMLTestRunner( stream=fp, title='测试结果', description='测试报告' ) #suite = unittest.TestLoader().loadTestsFromTestCase(ContactsAndroidTests) #unittest.TextTestRunner(verbosity=2).run(suite) runner.run(suite) #g_browser.quit() fp.close() #测试报告关闭


    excel

    username password duanyan 用例
    1111 1234567 请输入正确的手机号 smillphoone
    22222222222 1111111 请输入正确的手机号 longphone
      123456 请输入手机号 nullphone

     

    执行结果:

    charu

     

    转载于:https://www.cnblogs.com/hanzhao1987/p/5961952.html

    展开全文
  • 对于程序员来说,理想的目标是掌握一个通用的爬虫框架,每增加一个新目标网站就要跟着改代码,这显然不是好工作模式。这就是本篇文章的主要内容了,本文使用一个案例说明怎样将新定义的采集规则融入到爬虫框架中。也...

    一. 引言

    之前文章所用的例子中的规则都是固定的,如何自定义规则再结合提取器提取我们想要的网页内容呢?对于程序员来说,理想的目标是掌握一个通用的爬虫框架,每增加一个新目标网站就要跟着改代码,这显然不是好工作模式。这就是本篇文章的主要内容了,本文使用一个案例说明怎样将新定义的采集规则融入到爬虫框架中。也就是用可视化的集搜客GooSeeker爬虫软件针对亚马逊图书商品页做一个采集规则,并结合规则提取器抓取网页内容。

    二. 安装集搜客GooSeeker爬虫软件

    1. 前期准备

    进入集搜客官网产品页面,下载对应版本。我的电脑上已经安装了Firefox 38,所以这里只需下载爬虫。

    2. 安装爬虫

    打开Firefox –> 点击菜单工具 –> 附加组件 –> 点击右上角附加组件的工具 –> 选择从文件安装附加组件 -> 选中下载好的爬虫xpi文件 –> 立即安装

    下一步

    下一步

    三. 开始制作抓取规则

    1. 运行规则定义软件

    点击浏览器菜单:工具-> MS谋数台 弹出MS谋数台窗口。

    2. 做规则

    在网址栏输入我们要采集的网站链接,然后回车。当页面加载完成后,在工作台页面依次操作:命名主题名 -> 创建规则 -> 新建整理箱 -> 在浏览器菜单选择抓取内容,命名后保存。

    四. 申请规则提取器API KEY

    打开集搜客Gooseeke官网,注册登陆后进入会员中心 -> API -> 申请API

    五. 结合提取器API敲一个爬虫程序

    1.引入Gooseeker规则提取器模块gooseeker.py

    (下载地址: gooseeker/core at master · FullerHua/gooseeker · GitHub), 选择一个存放目录,这里为E:\demo\gooseeker.py

    2. 与gooseeker.py同级创建一个.py后缀文件

    如这里为E:\Demo\third.py,再以记事本打开,敲入代码:

    注释:代码中的31d24931e043e2d5364d03b8ff9cc77e 就是API KEY,用你申请的代替;amazon_book_pc 是规则的主题名,也用你的主题名代替

    # -*- coding: utf-8 -*-

    # 使用GsExtractor类的示例程序

    # 以webdriver驱动Firefox采集亚马逊商品列表

    # xslt保存在xslt_bbs.xml中

    # 采集结果保存在third文件夹中

    import os

    import time

    from lxml import etree

    from selenium import webdriver

    from gooseeker import GsExtractor

    # 引用提取器

    bbsExtra = GsExtractor()

    bbsExtra.setXsltFromAPI("31d24931e043e2d5364d03b8ff9cc77e", "amazon_book_pc") # 设置xslt抓取规则

    # 创建存储结果的目录

    current_path = os.getcwd()

    res_path = current_path + "/third-result"

    if os.path.exists(res_path):

    pass

    else:

    os.mkdir(res_path)

    # 驱动火狐

    driver = webdriver.Firefox()

    url = "https://www.amazon.cn/s/ref=sr_pg_1?rh=n%3A658390051%2Cn%3A!658391051%2Cn%3A658414051%2Cn%3A658810051&page=1&ie=UTF8&qid=1476258544"

    driver.get(url)

    time.sleep(2)

    # 获取总页码

    total_page = driver.find_element_by_xpath("//*[@class='pagnDisabled']").text

    total_page = int(total_page) + 1

    # 用简单循环加载下一页链接(也可以定位到下一页按钮,循环点击)

    for page in range(1,total_page):

    # 获取网页内容

    content = driver.page_source.encode('utf-8')

    # 获取docment

    doc = etree.HTML(content)

    # 调用extract方法提取所需内容

    result = bbsExtra.extract(doc)

    # 保存结果

    file_path = res_path + "/page-" + str(page) + ".xml"

    open(file_path,"wb").write(result)

    print('第' + str(page) + '页采集完毕,文件:' + file_path)

    # 加载下一页

    if page < total_page - 1:

    url = "https://www.amazon.cn/s/ref=sr_pg_" + str(page + 1) + "?rh=n%3A658390051%2Cn%3A!658391051%2Cn%3A658414051%2Cn%3A658810051&page=" + str(page + 1) + "&ie=UTF8&qid=1476258544"

    driver.get(url)

    time.sleep(2)

    print("~~~采集完成~~~")

    driver.quit()

    3. 执行third.py

    打开命令提示窗口,进入third.py文件所在目录,输入命令 :python third.py 回车

    4. 查看结果文件

    进入third.py文件所在目录,找到名称为result-2的文件夹然后打开

    六. 总结

    制作规则时,由于定位选择的是偏好id,而采集网址的第二页对应页面元素的id属性有变化,所以第二页内容提取出现了问题,然后对照了一下网页元素发现class是一样的,果断将定位改为了偏好class,这下提取就正常了。下一篇《Scrapy框架的安装和使用》简单介绍Scrapy的使用方法。

    End

    作者:华天清

    来源:知乎

    本文均已和作者授权,如转载请与作者联系。

    展开全文
  • 这里写自定义目录标题前言一、办公自动化基础1....因为初学掌握不到位,也还没学会怎样集成代码生成一个工具直接,只能一部分一部分附上代码。以下代码的比较好的。python版本为3.8。 特别说明

    前言

    初学python,主要目的是办公自动化,使用场景为日常办公,解决的问题为批量Word转PDF、合并PDF、奇数页插空白页(方便PDF合并后双面打印)、把Excel的内容插入Word批量生成周报等。
    因为初学掌握不到位,也还没学会怎样集成代码生成一个工具直接用,只能一部分一部分附上代码。以下代码是用的比较好的。python版本为3.8。
    特别说明:使用的代码为网上收集,稍加修改方便使用,特别感谢代码来源博主。
    python 还用过Excel内容插入Word批量生成文件、图片扫描成PDF识别,因为篇幅有限,暂不列出。感谢CSDN的前辈们。

    一、办公自动化基础

    办公自动化主要用到处理Word、Excel、PDF的工具,批量处理的实施。
    批量处理第一要用到 os 模块-去设置要处理的文件或放置文件的路径,第二是循环语句。其中代码中用到的模块可以用 pip install 模块名称 --index-url https://pypi.douban.com/simple 下载,–index-url 为使用镜像下载,这样快很多和避免报错。

    1.批量处理-import os

    import os
    os.getcwd(path) --获取当前路径
    os.chdir(r’c:----’)–改变当前路径,输入路径记得输入 “r” ,使路径不被转义。
    os.walk(path) 遍历路径下所有文件,是根目录-子目录-文件这样的遍历顺序。
    os.listdir(path)当前目录下所有文件(不包含子文件夹里的文件)。
    筛选PDF文件可以使用以下方法:
    1.判断 os.path.splitext(file)[1]==".pdf" 将文件名和扩展名分开。
    2.file.endswith(".pdf")
    3.file .spilt(".")[1] = = “pdf”
    补充知识【PYthon】os.path.splitext()与os.path.split()的区别

    2.批量处理-生成文件列表

    定义一个函数生成文件的绝对路径表,(os.path.join()合并路径与文件名)使用os.walk 遍历文件夹,使用 if 判断字符串以“PDF”结束。

    def getFileName(filedir):
    
        file_list = [os.path.join(root, filespath) \
                     for root, dirs, files in os.walk(filedir) \
                     for filespath in files \
                     if str(filespath).endswith('pdf')
                     ]
        return file_list if file_list else []
    

    3.批量处理-循环语句

    for i in range (循环次数):
    todo(操作)
    或者
    for i in list(某个列表):
    todo(操作)

    二、批量Word转PDF

    用到docx2pdf模块,简洁,比win32报错少。路径输入采用input的方式,基本保证路径不会被转义,也不用输入"\"。
    map 函数搭配lambda 自定义函数 生成绝对路径的文件名

    `#Word 转PDF
    #pip install --user -i https://pypi.tuna.tsinghua.edu.cn/simple/ docx2pdf
    
    from docx2pdf import convert
    import os
    
    #转换的文件路径
    director = input("请输入要转换的文件路径")
    FileList = map(lambda x: director + '\\' + x, os.listdir(director))
    for file in FileList:
        try:
            if file.endswith(".docx")or file.endswith(".doc"):
                print(file)
                convert(file, f"{file.split('.')[0]}.pdf")
        except:
                    print('could not convert')
        print ("finsh")
    
    

    参考链接:https://blog.csdn.net/cqcre/article/details/107218349

    三、奇数页插入空白PDF

    代码来源:利用python处理pdf:奇数页pdf末尾添加一个空白页
    代码来源知乎,只是修改了文件路径通过input的方式。

    #奇数页PDF插入空白页
    import os,PyPDF2,pyperclip
    pathofcwd = input("请输入要处理的PDF的文件路径")
    # ^ 需要处理的pdf存放位置
    class pdfReader:
        # ^ 处理pdf的一个类,把和pdf处理有关的代码都放在这里了
        blankPdfPath = input("请输入空白PDF的文件路径")
        # ^ 空白页pdf存放位置
        def __init__(self,pdfPath):
            self.pdfPath = pdfPath
            self.blankPageFile, self.blankPage = self.openAndReadit(self.blankPdfPath)
            self.pdfFile, self.pdfReader = self.openAndReadit(self.pdfPath)
        
        def openAndReadit(self,pdfpath):
            """
            generate the pdfReader object for given path in parameter
            """
            pdfFile = open(pdfpath, 'rb')
            pdfReader = PyPDF2.PdfFileReader(pdfFile)
            return (pdfFile,pdfReader)
    
        def appendBlank(self):
            """
            no para, return a pdf writer with blankPage appended
            """
            pdfWriter = PyPDF2.PdfFileWriter()
            for pageNum in range(self.pdfReader.numPages):
                pageObj = self.pdfReader.getPage(pageNum)
                pdfWriter.addPage(pageObj)
            # add the blank page:
            pdfWriter.addPage(self.blankPage.getPage(0))
            return pdfWriter
        
        def closeAllFile(self):
            self.blankPageFile.close()
            self.pdfFile.close()
    
    os.chdir(pathofcwd)
    fileList = os.listdir()
    
    pdfList = filter(
        lambda e:os.path.splitext(e)[1]=='.pdf',
        fileList
    )
    # ^ 过滤文件列表,只保留pdf
    
    pdfReaderList = map(
        lambda e:pdfReader(e),
        pdfList
    )
    # ^ 根据pdf文件路径生成pdfReader类
    
    pdfReaderList = filter(
        lambda e: e.pdfReader.numPages % 2 == 1,
        pdfReaderList
    )
    # ^ 只保留奇数页pdf的pdfReader类
    
    pdfReaderList = list(pdfReaderList)
    
    for pdfReader in pdfReaderList:
        pdfAddBlankWriter = pdfReader.appendBlank()
        outputPath = os.path.splitext(pdfReader.pdfPath)[0]+'_addBlank'+'.pdf'
        pdfOutputFile = open(outputPath,'wb')
        pdfAddBlankWriter.write(pdfOutputFile)
        pdfOutputFile.close()
        pdfReader.closeAllFile()
        print("preparing to output as:%s" % outputPath)
    

    四、合并PDF

    只是修改了文件路径通过input的方式。
    代码来源Python之合并PDF文件

    # -*- coding:utf-8-*-
    # 利用PyPDF2模块合并同一文件夹下的所有PDF文件
    # 只需修改存放PDF文件的文件夹变量:file_dir 和 输出文件名变量: outfile
    
    import os
    from PyPDF2 import PdfFileReader, PdfFileWriter
    import time
    
    # 使用os模块的walk函数,搜索出指定目录下的全部PDF文件
    # 获取同一目录下的所有PDF文件的绝对路径
    def getFileName(filedir):
    
        file_list = [os.path.join(root, filespath) \
                     for root, dirs, files in os.walk(filedir) \
                     for filespath in files \
                     if str(filespath).endswith('pdf')
                     ]
        return file_list if file_list else []
    
    # 合并同一目录下的所有PDF文件
    def MergePDF(filepath, outfile):
    
        output = PdfFileWriter()
        outputPages = 0
        pdf_fileName = getFileName(filepath)
    
        if pdf_fileName:
            for pdf_file in pdf_fileName:
                print("路径:%s"%pdf_file)
    
                # 读取源PDF文件
                input = PdfFileReader(open(pdf_file, "rb"))
    
                # 获得源PDF文件中页面总数
                pageCount = input.getNumPages()
                outputPages += pageCount
                print("页数:%d"%pageCount)
    
                # 分别将page添加到输出output中
                #可以通过range选择页面
                for iPage in range(pageCount):
                    output.addPage(input.getPage(iPage))
    
            print("合并后的总页数:%d."%outputPages)
            # 写入到目标PDF文件
            outputStream = open(os.path.join(filepath, outfile), "wb")
            output.write(outputStream)
            outputStream.close()
            print("PDF文件合并完成!")
    
        else:
            print("没有可以合并的PDF文件!")
    
    # 主函数
    def main():
        time1 = time.time()
        
        file_dir = input("请输入存放PDF的原文件夹路径") # 存放PDF的原文件夹  唯一修改地方
        outfile = input("输出的文件名称为") # 输出的PDF文件的名称
        MergePDF(file_dir, outfile)
        time2 = time.time()
        print('总共耗时:%s s.' %(time2 - time1))
    
    main()
    
    

    代码来源
    [1]Word转PDF
    [2]利用python处理pdf:奇数页pdf末尾添加一个空白页
    [3]Python之合并PDF文件

    展开全文
  • 模块管理函数 - 模块的概念 / 自定义模块管理函数 / 命名冲突的时候会怎样(同一个模块和不同的模块) Day07 - 字符串和常用数据结构 字符串的使用 - 计算长度 / 下标运算 / 切片 / 常用方法 列表基本用法 -...
  • 深入理解Python中文版高清PDF

    热门讨论 2012-09-04 19:37:04
     10.10 (现在)为什么异常   10.11 到底为什么要异常   10.12 异常和sys模块   10.13 相关模块   10.14 练习   第11章 函数和函数式编程   11.1 什么是函数?   11.1.1 函数vs过程...
  • Python核心编程第二版(中文)

    热门讨论 2015-04-23 16:40:13
    14.3.6 使用Python在运行时生成和执行Python代码 14.4 执行其他(Python)程序 14.4.1 导入 14.4.2 execfile() 14.4.3 将模块作为脚本执行 14.5 执行其他(非Python)程序 14.5.1 os.system() 14.5.2 os...
  • Python核心编程第二版

    热门讨论 2009-07-30 17:07:20
     10.10 (现在)为什么异常   10.11 到底为什么要异常   10.12 异常和sys模块   10.13 相关模块   10.14 练习   第11章 函数和函数式编程   11.1 什么是函数?   11.1.1 函数vs过程   ...
  • Python核心编程(中文第二版)

    热门讨论 2009-10-02 12:08:14
     10.10 (现在)为什么异常   10.11 到底为什么要异常   10.12 异常和sys模块   10.13 相关模块   10.14 练习   第11章 函数和函数式编程   11.1 什么是函数?   11.1.1 函数vs过程   ...
  • Python核心编程第二版(ok)

    热门讨论 2009-05-21 08:23:44
     10.10 (现在)为什么异常   10.11 到底为什么要异常   10.12 异常和sys模块   10.13 相关模块   10.14 练习   第11章 函数和函数式编程   11.1 什么是函数?   11.1.1 函数vs过程   ...
  • 原书名: Core Python Programming (2nd Edition) 原出版社: Prentice Hall PTR 作者: (美)Wesley J. Chun 译者: 宋吉广 出版社:人民邮电出版社 ISBN:9787115178503 上架时间:2008-6-23 出版日期:2008 ...
  • 原书名: Core Python Programming (2nd Edition) 原出版社: Prentice Hall PTR 作者: (美)Wesley J. Chun 译者: 宋吉广 出版社:人民邮电出版社 ISBN:9787115178503 上架时间:2008-6-23 出版日期:2008 ...
  • MYSQL

    2007-05-31 14:14:04
    4.13 OS/2 注意事项 4.14 TcX 二进制代码 4.15 安装后期(post-installation)的设置与测试 4.15.1 运行mysql_install_db 的问题 4.15.2 启动 MySQL 服务器的问题 4.15.3 自动启动和停止 ...
  • MySQL中文参考手册

    2010-08-10 22:11:55
    4.15.3 自动启动和停止 MySQL 4.15.4 选项文件 4.16 升级和降级(downgrading)时有什么特别要做的事情吗? 4.16.1 从一个 3.22 版本升级到 3.23 4.16.2 从一个 3.21 版本升级到 3.22 4.16.3 从一个 3.20 版本升级...
  • RED HAT LINUX 6大全

    热门讨论 2011-10-21 18:46:06
    7.2.8 自动生成sendmail.cf文件 124 7.2.9 测试sendmail和sendmail.cf 126 7.2.10 普通的sendmail配置错误 128 7.3 POP 128 7.3.1 配置POP服务器 128 7.3.2 配置ipop3d 128 7.3.3 APOP如何工作 129 7.3.4 设置APOP...
  • MySQL中文参考手册.chm

    热门讨论 2007-06-11 21:31:17
    4.13 OS/2 注意事项 4.14 TcX 二进制代码 4.15 安装后期(post-installation)的设置与测试 4.15.1 运行mysql_install_db 的问题 4.15.2 启动 MySQL 服务器的问题 4.15.3 自动启动和停止...
  • 添加其它语言如Java、python、go 的代码,放在ebook/code文件夹内,同样如上,注意代码命名规范的问题。 「可选」 重绘所有的图片:https://github.com/julycoding/The-Art-Of-Programming-by-July/issues/80 翻译...
  • 测试培训教材

    2014-04-01 12:10:48
    7、生成自动化测试脚本、BPT模型 产生自动化测试脚本 是否需要实现自动化: 自动化实现“Cruise Search”测试用例: 定位到“Cruise Search”测试用例,在“设计步骤”界面中选择“生成脚本->QUICKTEST_TEST”...
  • 软件工程教程

    热门讨论 2012-07-06 23:10:29
    例图所描述的系统功能依靠外部用户或另一个系统激活,为用户或另一个系统提供服务 用例表达“做什么” 例图中可以包含若干个用例,用例表达了系统的功能 用例只描述参与者和系统在交互过程中做些什么,并不描述...
  • 你只需要30分钟就可以将PHP的核心语言特点全部掌握,你可能已经非常了解HTML,甚至你已经知道怎样用编辑设计软件或者手工来制作好看的WEB站点。由于PHP代码能够无障碍的添加进你的站点,在你设计和维护站点的同时,...
  • 2.3.3. 用自动安装器安装MySQL 2.3.4. 使用MySQL安装向导 2.3.5. 使用配置向导 2.3.6. 通过非安装Zip文件安装MySQL 2.3.7. 提取安装档案文件 2.3.8. 创建选项文件 2.3.9. 选择MySQL服务器类型 2.3.10. 首次启动...
  • MYSQL中文手册

    2013-03-11 21:21:34
    2.3.3. 用自动安装器安装MySQL 2.3.4. 使用MySQL安装向导 2.3.5. 使用配置向导 2.3.6. 通过非安装Zip文件安装MySQL 2.3.7. 提取安装档案文件 2.3.8. 创建选项文件 2.3.9. 选择MySQL服务器类型 2.3.10. 首次...
  • 这个代码仓库里是博客中涉及的源码、文件等 如果对您有帮助,请给个Star,谢谢您! 文章分类 总的来说分为以下几大类,若有您感兴趣的内容,我将不胜荣幸: Java; 后台中间件; Docker; Kubernetes; 大数据; ...
  • 2.3.3. 用自动安装器安装MySQL 2.3.4. 使用MySQL安装向导 2.3.5. 使用配置向导 2.3.6. 通过非安装Zip文件安装MySQL 2.3.7. 提取安装档案文件 2.3.8. 创建选项文件 2.3.9. 选择MySQL服务器类型 2.3.10. 首次启动...
  • 2.3.3. 用自动安装器安装MySQL 2.3.4. 使用MySQL安装向导 2.3.5. 使用配置向导 2.3.6. 通过非安装Zip文件安装MySQL 2.3.7. 提取安装档案文件 2.3.8. 创建选项文件 2.3.9. 选择MySQL服务器类型 2.3.10. 首次...
  • MySQL 5.1参考手册

    2010-04-20 22:02:50
    2.3.3. 用自动安装器安装MySQL 2.3.4. 使用MySQL安装向导 2.3.5. 使用配置向导 2.3.6. 通过非安装Zip文件安装MySQL 2.3.7. 提取安装档案文件 2.3.8. 创建选项文件 2.3.9. 选择MySQL服务器类型 2.3.10. 首次启动...

空空如也

空空如也

1 2
收藏数 38
精华内容 15
关键字:

怎样用python自动生成python代码

python 订阅