本章知识点 :> 字符串实战
北京地铁
字符串函数
- 现在说一说其他的一些字符串函数
-
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读取这个网站的网页,输入 英文 输出中文,帮我完成翻译吗?
答案是肯定的
-
image.png
试一下 在线Python
翻译实现
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