《金哥百变Python零基础教程9》~实战II

本章知识点 :> 字符串实战

字符串函数

  • 现在说一说其他的一些字符串函数
    • in 语法
    • 如果判断一个字符串在另一个字符串里?

s = 'abc'
print('a' in s)
print('bc' in s)
print('xyz' in s)

试一下 在线Python

  • strip rstrip lstrip
  • 这3个函数是处理字符串前后的一些多余字符

  • s = ' abc ' #注意这个字符串前后有空格
    s1 = s.strip() #前后全去
    print(s1)
    s2 = s.lstrip() #前去
    print(s2)
    s3 = s.rstrip() #后去
    print(s3)

    试一下 在线Python
  • replace 替换函数

  • 字符串查找替换是很常见的需求。

  • s = 'abc'
    s1 = s.replace('ab', 'ef')
    print(s1)
  • 易错点:s.replace 会返回替换完的字符串,s本身不会改变


    试一下 在线Python


json库

  • json 是一种特殊的字符串
  • 解决这样一类问题:网络上有个程序A,你的电脑上有个程序B,如果A想要把某些变量传递给程序B的时候
  • 程序A可以用json 把自己的变量转成 json;程序B接收这个json,再转成自己的变量
  • 这样就完成了变量的传递
  • image.png

  • 不用管这个描述里的python对象,你理解为变量即可

    • 比如:

    import json
    v = [1, {'a':True, 'b':1001}, "abc", None, 123, [0,1,2]]
    #把v转成字符串
    s = json.dumps(v)

    #假设另一个程序

    v1 = json.loads(s)
    print(v1) #你会看到v1和v完全一样

    试一下 在线Python
    • https://www.json.cn/ 这个网站可以在线解析json (一个json字符串可能很大,可以解析一下看的更清晰)

requests库

  • 怎么通过python来读取网页内容?
  • 或者说我的Python程序怎么获取网络上的资源?(网页,接口,数据,爬虫等)

  • requests 有很多个库可以完成这些功能,但requests是其中最容易的。

  • 我们尝试获取一下百度首页内容(需要注意url)
  • url其实就是你用浏览器访问网页的地址 image.png
  • 注意看我红线画的部分!
  • 还有一点,其实网页通过程序请求之后,是html格式的,不是你看到的这种界面(界面不是一种数据)
  • html也是一种特殊字符串,(谁能读懂html呢?各种浏览器可以读懂它,并且显示成界面(所以我说网页请求不直接返回界面))
  • 还不是很理解也没事,只要记住,用requests请求任何网络的url地址,返回的都不是界面,而是字符串(html 或 json)

import requests
url = ’http://www.baidu.com‘ #url需要用http开头
response = requests.get(url)
html = response.text #注意,这里text为什么不加text(),因为text是response里的变量,不是函数
ishtml = html.find('html') #看看html字符串是不是包含'html’字样


试一下 在线Python


翻译需求

北京地铁

  • 地铁里经常遇到说英文的乘客,现在请你的程序可以完成 英语-汉语的翻译
    试一下 在线Python

翻译思路

  • 这个问题太实际了!
  • 一时真的没有思路,英文-字符串 汉语-字符串?难道我要写一个字典?
  • 但是字典能存下说有的语句吗?(不现实)
  • 直到,我遇到一个叫 有道翻译 的网站。
  • 可以用Python读取这个网站的网页,输入 英文 输出中文,帮我完成翻译吗?
  • 答案是肯定的

  • http://fanyi.youdao.com/ image.png


翻译实现

import json
import requests

翻译函数,word 需要翻译的内容

def translate(word):
    # 有道词典 api
    url = 'http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule&smartresult=ugc&sessionFrom=null'
    # 传输的参数,其中 i 为需要翻译的内容
    key = {
    'type': "AUTO",
    'i': word,
    "doctype": "json",
    "version": "2.1",
     "keyfrom": "fanyi.web",
    "ue": "UTF-8",
    "action": "FY_BY_CLICKBUTTON",
     "typoResult": "true"
     }

     # key 这个字典为发送给有道词典服务器的内容
     response = requests.post(url, data=key)
     # 判断服务器是否相应成功
     if response.status_code == 200:
          # 然后相应的结果
          return response.text
     else:
          print("有道词典调用失败")
          # 相应失败就返回空
          return None


def get_reuslt(repsonse):
     # 通过 json.loads 把返回的结果加载成 json 格式
     result = json.loads(repsonse)
     #print ("输入的词为:%s" % result['translateResult'][0][0]['src'])
     #print ("翻译结果为:%s" % result['translateResult'][0][0]['tgt'])
     return result['translateResult'][0][0]['tgt']

  • 别问我为什么能拼出key里面的内容(这需要一点点的http知识)
  • 别问我为什么知道用resuests.post方法(这需要另一点http知识和网页知识)
  • 现在你只需要能成功调试出我写的代码即可(不要纠结key和post的太多细节)
  • 在现实编程中,我们经常会直接使用别人的代码

    试一下 在线Python

Sorry but the SQLBolt exercises require a more recent browser to run.
Please upgrade to the latest version of Internet Explorer, Chrome, or Firefox!

Otherwise, continue to the next lesson: SQL Lesson 2: Queries with constraints (Pt. 1)
Python小机器人嘴巴会打印东西,还可以拖动
练习 do it — 请完成如下任务
我不会做求助!求助!

继续努力 学下一节