P站爬虫

  • 1:运行环境
  • 2:写代码时碰到的难点
    • 2.1 登陆问题
    • 2.2 反爬的几个参数设置
  • 最后的总结和所有代码

想法:源于本学期学校的一个课程,老师要求使用一门语言写一个程序,老师也不管你写的什么,反正就是自己学自己写一个小程序,作为二翅猿的我就想到了爬pixiv原图,省掉手一个个保存还能提交期末作业哈哈哈哈

部分思路参考CSDN另一篇文章,给我提供了很大帮助
从零开始实现pixiv爬虫

1:运行环境

Python3.8
selenium
requests
lxml

Selenium需要使用Chromedriver并设置路径

驱动下载链接:
Chromedriver

  
#executable_path为路径
bro = webdriver.Chrome(executable_path='该位置为chromedriver存放路径',chrome_options=chrome_options, options=option)

2:写代码时碰到的难点

2.1 登陆问题

登陆需要处理四个参数
pixiv_idpassword 就是自己的账号密码
重点就是 post_key和 Racaptcha_v3_token 这两个参数

post_key很简单拿到,通过抓包可以看到,在登陆网页:
https://accounts.pixiv.net/loginreturn_to=https%3A%2F%2Fwww.pixiv.net%2Fen%2F&lang=en&source=pc&view_type=page

然后用etree xpath可以解析到post_key

在这里插入图片描述

重点是这个Racaptcha_v3_token到底是什么
登陆需要的参数
经过baidu baidu google google,发现这是google v3人机验证,这就没办法了
卡了一段时间
因为没有经验边学边查资料找方法,后来学到了selenium模块能够使用chromedriver进行模拟登陆获取cookie然后进行爬取。然后写写写。。。。

代码如下:
因为爬排行榜不需要登陆所以这里写的拿cookie拿的是画师id对应界面的cookie
代码为类里的片段,完整放在最后

    def get_cookie(self, art_id):  # 使用selenium模块进行模拟登陆chrome_options = Options()  # 切换无头浏览器chrome_options.add_argument('--headless')chrome_options.add_argument('--disable-gpu')option = ChromeOptions()  # 改参数反爬option.add_experimental_option('excludeSwitches', ['enable-automation'])bro = webdriver.Chrome(executable_path='/usr/local/bin/chromedriver',chrome_options=chrome_options, options=option)# bro = webdriver.Chrome(executable_path='/usr/local/bin/chromedriver', options=option)url = 'https://accounts.pixiv.net/login?return_to=https%3A%2F%2Fwww.pixiv.net%2Fen%2Fusers%2F' + art_id + '&lang=en&source=pc&view_type=page'bro.get(url)if self.username is None:self.username = str(input("请输入用户名"))if self.password is None:self.password = str(input("请输入密码"))user_tag = bro.find_element_by_xpath('//*[@id="LoginComponent"]/form/div[1]/div[1]/input')  # 定位按钮user_tag.send_keys(self.username)time = [0.1, 0.2, 0.3, 0.4, 0.5, 0.6]sleep(random.choice(time))pass_tag = bro.find_element_by_xpath('//*[@id="LoginComponent"]/form/div[1]/div[2]/input')pass_tag.send_keys(self.password)bro.find_element_by_xpath('//*[@id="LoginComponent"]/form/button').click()sleep(3.5)cookie_item = bro.get_cookies()  # 获取cookiecookie_str = ''# page_text = bro.page_source# print(page_text)bro.quit()for item_cookie in cookie_item:  # 拼接cookieitem_str = item_cookie["name"] + "=" + item_cookie["value"] + ";"cookie_str += item_strreturn cookie_str

重点在sleep(3.5),如果不让程序停一会,获取cookie过快会导致获取的cookie不全,导致后面抓取画师id页面的时候会抓不全插画id。拿到cookie之后就可以进行下一步,爬取画师ID对应的所有插画id

2.2 反爬的几个参数设置

进入某画师的页面之后会,抓包工具里的XHR会抓到这些个东西。all?lang=zh
其中all?lang=zh的request url为https://www.pixiv.net/ajax/user/1114585/profile/all?lang=zh 其中1114585为画师id
重点是下面的referer参数和x-user-id参数再配合get_cookie拿到的该id页面的cookie,其中referer为上级请求页面
格式为https://www.pixiv.net/users/ + 画师ID。 x-user-id为自己登陆的账号的id

基于这几个参数又可以拿到画师ID页面的json数据,拿到json解析网站上可以发现里面含有该画师所有插画id

在这里插入图片描述

于是通过代码实现抓取所有的ID
代码如下:

    def liked_user_illustlist(self, likedUser_id):headers = self.headers.copy()likedUser_id = str(likedUser_id)illust_id_list = []'''需要登陆后的cookie和x-user-id以及referer防盗链referer为上级页面'''headers['cookie'] = self.get_cookie(likedUser_id)headers['x-user-id'] = '15691732'headers['referer'] = 'https://www.pixiv.net/users/' + likedUser_id# headers['sec-fetch-site']= 'same-origin'# headers['sec-fetch-mode'] = 'cors'# headers['sec-fetch-dest'] = 'empty'json_url = 'https://www.pixiv.net/ajax/user/' + likedUser_id + '/profile/all?lang=en'try:json_load = requests.get(url=json_url, headers=headers, proxies=random.choice(self.proxy))except:print('Get user illust list Error')else:if json_load.status_code == 200:print("Get liked user illust list successful")json_text = json.loads(json_load.text)for value in json_text['body']['illusts']:illust_id_list.append(value)self.img_path = self.img_path + 'user/' + likedUser_id + '/'if os.path.exists(self.img_path):os.mkdir(self.img_path)return illust_id_list  # 返回id的列表else:print("Get liked user illust list Error")

走到这里拿到插画id就已经差不多了,最后就是把插画id里的图片全部解析出来就可以来下载了。
因为有些插画id页面有多个图片,所以这里需要单独对每张页面进行解析,来得到原图url。因为有防盗链机制直接在浏览器进入原图url会显示404。所以得对参数进行设置,总之先解析到再说。

进入画师的页面对页面进行抓包然后可以找到在在这里插入图片描述
在这里插入图片描述

以插画id为首的XHR请求里找到请求url和相关参数,然后看到响应数据为json数据之后在response里复制响应数据,然后丢到json解析,结果为下图
在这里插入图片描述
可以发现original里的链接就是原图对应的链接
直接用json模块对id页面的原图链接进行爬取

    def get_original_url(self, illust_id):  # 参数为单个插画idheaders = self.headers.copy()original_url_list = []the_original_url = 'https://www.pixiv.net/ajax/illust/' + str(illust_id) + '/pages?lang=zh'  # json requests urltry:  # request json data to get real pixiv_img urlurl_get = requests.get(url=the_original_url, headers=headers, proxies=random.choice(self.proxy),timeout=1000)except:print("Get illust original_url json Error")else:if url_get.status_code == 200:url_get = url_get.textoriginal_json = json.loads(url_get)for dict_urls in original_json['body']:original_url = dict_urls['urls']['original']original_url_list.append(original_url)else:print("Get illust original_url json load Error")return original_url_list  # 返回原图片链接的列表(可能有多个链接

返回的原图链接的列表

接下来到了下载,下载很简单只需要设置referer参数就可以request到图片数据
代码如下:

    def download_pic(self, url):  # 根据原图片链接进行下载title = url.split('/')[-1]  # 获取图片名称headers = self.headers.copy()headers['referer'] = 'https://www.pixiv.net/ranking.php?mode=monthly'path = self.img_path + '/' + titletry:pic_get = requests.get(url=url, headers=headers,proxies=random.choice(self.proxy))except:print(f"Original img.content download error")else:if not os.path.exists(self.img_path):os.mkdir(self.img_path)with open(path, 'wb') as fp:try:fp.write(pic_get.content)print(f"{title} saved")sleep(0.3)except:print(f'Img {title} save error')

最后是排行榜的爬取,这个是最简单的不需要登陆就能进行爬取

    def get_rank_id_list(self, date, number, mode, content=None):  # 获取排行榜插画id# 设置动态参数self.params_rank = {  # 排行榜参数'mode': 'daily','content': 'illust','date': '','p': '1','format': 'json',}headers = self.headers.copy()headers['referer'] = 'https://www.pixiv.net/ranking.php'self.params_rank['mode'] = modeif content == None:del self.params_rank['mode']else:self.params_rank['content'] = contentself.params_rank['date'] = datepage = math.ceil(number / 50)  # 计算需要爬取的json页面 1page有50个插画illust_id_list = []for i in range(1, int(page) + 1):self.params_rank['p'] = str(page)try:url_get = requests.get(url=self.url_rank, headers=headers, proxies=random.choice(self.proxy),params=self.params_rank)except:print(f"Get {date} json_page {i} timeout")else:if url_get.status_code == 200:print(f"Get {date} json_page {i} successful")url_get = url_get.texturl_json = json.loads(url_get)json_list = url_json['contents']for dict in json_list:user_id = dict['illust_id']number = int(number) - 1illust_id_list.append(user_id)self.img_path = self.img_path + 'rank/' + dateif not os.path.exists(self.img_path):os.mkdir(self.img_path)# if not os.path.exists(self.img_path):#     os.mkdir(self.img_path)return illust_id_list[0:number]else:print(f"Get {date} json_page {i} Error")

页面参数params是根据排行榜类型进行分析的
https://www.pixiv.net/ranking.phpmode=daily&content=illust&date=20200731
比如上面页面mode daily就是日榜
content=illust是插画排行 date是日期
然后综合排行榜没有content参数
在这里插入图片描述

最后的总结和所有代码

目前写了排行榜以及画师id 两个功能
可以选择综合排行榜和插画排行榜以及下面的筛选功能

最后完整代码的项目也放到了github
链接:P站爬虫

最后放完整代码

#作者:毛毛鱼iiiii
import json
import os
import requests
import random
import math
from multiprocessing.dummy import Pool
from lxml import etree
import re
from selenium import webdriver
from selenium.webdriver.chrome.options import Options
from selenium.webdriver import ChromeOptions
from time import sleep# 部分思路学习 https://blog.csdn.net/weixin_44127580/article/details/106874830# bro = webdriver.Chrome(executable_path='/usr/local/bin/chromedriver',options=option)class Pixiv(object):headers_list = ['Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_6) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/13.1.2 Safari/605.1.15','Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.89 Safari/537.36','Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:21.0) Gecko/20100101 Firefox/21.0','Mozilla/5.0 (Windows NT 6.2; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/27.0.1453.94 Safari/537.36','Mozilla/5.0 (Windows NT 6.2; WOW64; rv:21.0) Gecko/20100101 Firefox/21.0']referer_url = 'https://www.pixiv.net'img_path = ''username = Nonepassword = None# session = requests.Session()def __init__(self):self.headers = {'User-Agent': random.choice(self.headers_list),'referer': self.referer_url,"Accept-Language": "en-US,en;q=0.9,zh-CN;q=0.8,zh;q=0.7","Accept-Encoding": "gzip, deflate, br",# 'cookie': get_cookie(),    #排行榜不需要cookie所以注释掉}self.user_id = ''self.url_rank = 'https://www.pixiv.net/ranking.php?'# 使用代理进行爬取self.proxy = []self.ips = get_ips()# 这里爬的某免费代理 建议自己写一个爬代理的模块#源码就不放这里了for ip in self.ips:  # 将ip地址转化为http的字典self.ip_dict = {'http': ip}self.proxy.append(self.ip_dict)def get_cookie(self, art_id):  # 使用selenium模块进行模拟登陆chrome_options = Options()  # 切换无头浏览器chrome_options.add_argument('--headless')chrome_options.add_argument('--disable-gpu')option = ChromeOptions()  # 改参数反爬option.add_experimental_option('excludeSwitches', ['enable-automation'])bro = webdriver.Chrome(executable_path='/usr/local/bin/chromedriver',chrome_options=chrome_options, options=option)# bro = webdriver.Chrome(executable_path='/usr/local/bin/chromedriver', options=option)url = 'https://accounts.pixiv.net/login?return_to=https%3A%2F%2Fwww.pixiv.net%2Fen%2Fusers%2F' + art_id + '&lang=en&source=pc&view_type=page'bro.get(url)if self.username is None:self.username = str(input("请输入用户名"))if self.password is None:self.password = str(input("请输入密码"))user_tag = bro.find_element_by_xpath('//*[@id="LoginComponent"]/form/div[1]/div[1]/input')  # 定位按钮user_tag.send_keys(self.username)time = [0.1, 0.2, 0.3, 0.4, 0.5, 0.6]sleep(random.choice(time))pass_tag = bro.find_element_by_xpath('//*[@id="LoginComponent"]/form/div[1]/div[2]/input')pass_tag.send_keys(self.password)bro.find_element_by_xpath('//*[@id="LoginComponent"]/form/button').click()sleep(3.5)cookie_item = bro.get_cookies()  # 获取cookiecookie_str = ''# page_text = bro.page_source# print(page_text)bro.quit()for item_cookie in cookie_item:  # 拼接cookieitem_str = item_cookie["name"] + "=" + item_cookie["value"] + ";"cookie_str += item_strreturn cookie_strdef get_rank_id_list(self, date, number, mode, content=None):  # 获取排行榜插画id# 设置动态参数self.params_rank = {  # 排行榜参数'mode': 'daily','content': 'illust','date': '','p': '1','format': 'json',}headers = self.headers.copy()headers['referer'] = 'https://www.pixiv.net/ranking.php'self.params_rank['mode'] = modeif content == None:del self.params_rank['mode']else:self.params_rank['content'] = contentself.params_rank['date'] = datepage = math.ceil(number / 50)  # 计算需要爬取的json页面 1page有50个插画illust_id_list = []for i in range(1, int(page) + 1):self.params_rank['p'] = str(page)try:url_get = requests.get(url=self.url_rank, headers=headers, proxies=random.choice(self.proxy),params=self.params_rank)except:print(f"Get {date} json_page {i} timeout")else:if url_get.status_code == 200:print(f"Get {date} json_page {i} successful")url_get = url_get.texturl_json = json.loads(url_get)json_list = url_json['contents']for dict in json_list:user_id = dict['illust_id']number = int(number) - 1illust_id_list.append(user_id)self.img_path = self.img_path + 'rank/' + dateif not os.path.exists(self.img_path):os.mkdir(self.img_path)# if not os.path.exists(self.img_path):#     os.mkdir(self.img_path)return illust_id_list[0:number]else:print(f"Get {date} json_page {i} Error")def liked_user_illustlist(self, likedUser_id):headers = self.headers.copy()likedUser_id = str(likedUser_id)illust_id_list = []'''需要登陆后的cookie和x-user-id以及防盗链链接referer为上级html页面'''headers['cookie'] = self.get_cookie(likedUser_id)headers['x-user-id'] = '15691732'headers['referer'] = 'https://www.pixiv.net/users/' + likedUser_id# headers['sec-fetch-site']= 'same-origin'# headers['sec-fetch-mode'] = 'cors'# headers['sec-fetch-dest'] = 'empty'json_url = 'https://www.pixiv.net/ajax/user/' + likedUser_id + '/profile/all?lang=en'try:json_load = requests.get(url=json_url, headers=headers, proxies=random.choice(self.proxy))except:print('Get user illust list Error')else:if json_load.status_code == 200:print("Get liked user illust list successful")json_text = json.loads(json_load.text)for value in json_text['body']['illusts']:illust_id_list.append(value)self.img_path = self.img_path + 'user/' + likedUser_id + '/'if os.path.exists(self.img_path):os.mkdir(self.img_path)return illust_id_list  # 返回id的列表else:print("Get liked user illust list Error")def get_original_url(self, illust_id):  # 参数为单个插画idheaders = self.headers.copy()original_url_list = []the_original_url = 'https://www.pixiv.net/ajax/illust/' + str(illust_id) + '/pages?lang=zh'  # json requests urltry:  # request json data to get real pixiv_img urlurl_get = requests.get(url=the_original_url, headers=headers, proxies=random.choice(self.proxy),timeout=1000)except:print("Get illust original_url json Error")else:if url_get.status_code == 200:url_get = url_get.textoriginal_json = json.loads(url_get)for dict_urls in original_json['body']:original_url = dict_urls['urls']['original']original_url_list.append(original_url)else:print("Get illust original_url json load Error")return original_url_list  # 返回原图片链接的列表(可能有多个链接def download_pic(self, url):  # 根据原图片链接进行下载title = url.split('/')[-1]  # 获取图片名称headers = self.headers.copy()headers['referer'] = 'https://www.pixiv.net/ranking.php?mode=monthly'path = self.img_path + '/' + titletry:pic_get = requests.get(url=url, headers=headers,proxies=random.choice(self.proxy))except:print(f"Original img.content download error")else:if not os.path.exists(self.img_path):os.mkdir(self.img_path)with open(path, 'wb') as fp:try:fp.write(pic_get.content)print(f"{title} saved")sleep(0.3)except:print(f'Img {title} save error')def mode_1_list(self):def check_dict(dict):for key, value in dict.items():print(key, value)while True:mode_input = input("---->").strip()if mode_input in mode_dict.keys():mode_c = mode_dict[mode_input]breakelse:print('输入错误,应为对应编号')date_c = input("请输入排行榜日期: ")pic_num_c = int(input("请输入要下载前多少名: "))return mode_c, date_c, pic_num_cwhile True:model = str(input('请选择综合排行榜或者插画排行榜: \n1 : all \n2 : illust\n或输入0退出\n---->').strip())if model == '2':content = 'illust'mode_dict = {'1': 'daily','2': 'weekly','3': 'monthly','4': 'rookie',}print("请选择请选择插画排行榜的模式 :")mode, date, pic_num = check_dict(mode_dict)id_list = self.get_rank_id_list(date, pic_num, mode, content)return id_listelif model == '1':mode_dict = {'1': 'daily','2': 'weekly','3': 'monthly','4': 'rookie','5': 'male','6': 'female',}print("请选择请选择综合排行榜的模式 :")mode, date, pic_num = check_dict(mode_dict)id_list = self.get_rank_id_list(date, pic_num, mode)return id_listelif model == '0':exit('程序已退出')else:print("输入错误,应为对应编号")def mode_2_list(self):user_id = input('请输入喜欢的画师ID\n----> ')print("将下载该画师所有插画")return self.liked_user_illustlist(user_id)def run(self):count = 0while count < 3:select = int(input("请选择需要下载的模式: \n1:排行榜模式  \n2:画师ID模式\n----> ").strip())if select == 1:url_list = self.mode_1_list()self.download(url_list)breakelif select == 2:url_list = self.mode_2_list()self.download(url_list)breakelse:print('请输入数字1或2')count += 1if count == 3:print('瞎输入,程序已退出')def download(self, id_list):  # 下载 ,参数为ID列表pool_num = 8pool = Pool(pool_num)  # 开启线程池original_list = pool.map(self.get_original_url, id_list)  # 多线程获取图片原地址the_original_list = []max_num = int(input('请输入单页插画数量来跳过该id\n---->'))for id_url_list in original_list:  # 循环列表提取列表里的列表,将列表中的列表链接转变为一个大的列表if len(id_url_list) > max_num:  # 如果列表中原图片链接大于指定输入值则跳过该idcontinueelse:for ori_url in id_url_list:  # 循环列表里的图片地址the_original_list.append(ori_url)pool.map(self.download_pic, the_original_list)  # 多线程下载print(f"下载图片结束,共{len(the_original_list)}张图片")pool.close()  # Close poolpool.join()if __name__ == '__main__':'''实例化Pixiv对象然后调用函数的run'''p = Pixiv()p.img_path = './pixiv_img/'  # 修改此项更改文件存储路径 最后以斜杠结尾 如果不存在将会创建路径# 使用喜欢的画师模式需要输入下面三个参数p.username = '' # 输入用户名p.password = ''  # 输入密码p.user_id = ''  # 输入自己登陆后的账户ID,在自己的页面p.run()

PS:
get_ips这个功能被我删掉了,可以自己写一个爬取代理ip的函数然后调用就行了
如果不使用proxy的话要将每个方法里的requests.get里的proxies参数删掉

仅学习目的和自用
不要大量爬取干扰网站正常运作
欢迎指出bug和优化方案
github将不断优化更新增加新功能

查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. [Unity][Rigidbody]使用刚体进行移动的时候会滑动

    无论是3D刚体还是2D刚体的移动,产生向前滑动的时候,都可以锁定位移。横板2D 角色进行移动的时候rig.constraints = RigidbodyConstraints2D.None;rig.constraints = RigidbodyConstraints2D.FreezeRotation;横板2D 锁定2D刚体滑动位移rig.constraints = RigidbodyConstraints…...

    2024/4/15 18:05:16
  2. Day54——数据访问简介以及准备工程环境

    文章目录一. 回顾二. 数据访问简介三. 搭建工程环境 一. 回顾 前面学习了关于Docker的使用,今天开启新篇章数据访问 二. 数据访问简介三. 搭建工程环境...

    2024/4/15 15:06:51
  3. Python中的Print()

    print("epoch%d/%d:%.6f"%(epoch,epoch_num,l1_loss.item())用%隔开,前面和C语言一样,后面用()包围所有的变量。...

    2024/4/15 15:06:49
  4. JavaScript 的基本规范

    1,不要在同一行声明多个变量。 2,请使用 ===/!==来比较 true/false 或者数值 3,使用对象字面量代替new Array 这种形式 4,不要使用全局函数 5,Switch语句必须带有 default 分支 6,函数不应该有时候有返回值,有时候没有返回值。 7,For循环必须使用大括号 8,if语句必须使…...

    2024/4/15 15:06:47
  5. SwiftUI 联合size和postion设置动画 matchGeometryEffect使用教程

    实战需求 在上一篇《SwiftUI 2 超酷新修饰器matchGeometryEffect之做个数字切换效果》中我们学会了matchGeometry的基础使用,本文我们将更深入一步探索个性化变量设置。 本文价值与收获 看完本文后,您将能够作出下面的界面看完本文您将掌握的技能 掌握properties设置方法 掌握…...

    2024/4/15 15:06:46
  6. Springboot + Demo RPC分布式应用搭建

    Table of Contents背景前置条件应用整体架构安装zookeeper创建dubbo-share应用创建dubbo-Provider应用创建dubbo-consumer应用Dubbo Admin部署测试效果Referrence背景本文描述了Dubbo RPC调用、服务注册、服务发现的Demo搭建的过程,原理性的东西不涉及,主要讲述实践过程。应用…...

    2024/4/15 15:06:45
  7. 游戏跨平台:数学库

    08/02/2020游戏跨平台需要数学库SIMD与SSE2指令集加速DirectXMathXMVECTOR结构XMFLOATGLMGLM的文件目录GLM跨平台代码宏定义不同平台声明部分定义部分确定完操作系统,需要进一步确定编译器声明定义确定完编译器,确认指令集声明定义部分总结 最近看了看PS4 SDK文档,也阅读了它…...

    2024/4/15 15:06:44
  8. 【CPU毫秒级】极验点选识别

    聊一聊测评机器我看到市面上大多是Yolo实现的点选服务,什么各种DLL库满天飞,被易语言中间商贱卖到几百一套,笔者白嫖了几个这样的本地识别库,果然性能是不行的,并发几个就挂了,即使用上GPU也才达到我这个服务器CPU的性能水准,有多慢用过的应该知道,或许有的人做的还达不…...

    2024/4/15 15:06:43
  9. ECMAScript常用整理

    ECMAScript 2019 (ES10)Array.prototype.flat() Array.prototype.flatMap() 重写toString()方法 可选的捕获Array.prototype.flat() 用于数组扁平化,递归地将数组展平到我们指定的深度。如果未指定depth参数,则默认值为1。 var newArray = arr.flat([depth]); depth 选择性,…...

    2024/4/15 15:06:42
  10. View的滑动冲突---常见的滑动冲突场景

    常见的滑动冲突场景可以简单分为如下三种: 场景1 - 外部滑动方向和内部滑动方向不一致 场景2 - 外部滑动方向和内部滑动方向一致 场景3 - 上面两张情况的嵌套先说场景1,主要是将ViewPager和Fragment配合使用所组成的页面滑动效果,主流应用几乎都会使用这个效果。在这种效果中…...

    2024/4/15 18:05:15
  11. VS2015社区版update3无法查看STL内容的解决方法

    使用update2版本。 在官网下载的默认就是update3版本,调试的时候STL中元素的内容显示不出来,试了各种方法(本机兼容模式不勾选、在变量窗口显示对象的原始结构不勾选、natvis),仍未解决。经查, VS调试STL问题总结中提到了这是个update3版本的bug,Visual studio 2015 com…...

    2024/4/15 18:05:14
  12. springboot框架学习

    一、运行环境jdk1.8;IDEA2018;springboot 2.3.2; 二、搭建步骤1.pom.xml配置文件内容<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLS…...

    2024/4/15 18:05:13
  13. linux文件权限?学这一篇基本操作就会了,两分钟就读完

    内容简介: linux的文件权限不像window系统那样的直观。但是当你看懂它的权限字段的结构和含义后发现原来是如此的简单。文章目录查看权限权限字段的解释chmod命令的使用chmod 参数对照表总结 查看权限 输入命令:ls -l [文件名] 查看权限,后面不跟文件名的话查看的是整个目录…...

    2024/4/15 18:05:12
  14. 性能测试 笔记533,333

    性能测试本质基于协议模拟用户发出请求(业务模拟), 服务器形成一定的负载,来测试服务器性能指标是否满足要求关注点: 时间性能 空间性能性能测试分类性能测试(狭义)性能测试方法通过模拟生产运行的业务压力量和使用场景组合.测试系统的性能是否满足生产性能要求.通俗的说,这种方…...

    2024/4/15 18:05:11
  15. android studio3.4.1 gradle-5.1.1 配置 apt

    android studio3.4.1 gradle-5.1.1 配置 apt ,实现黄油刀(ButterKnife)效果遇到的问题及最新方法:apt简介:APT(Annotation Processing Tool)是一种处理注释的工具,它对源代码文件进行检测找出其中的Annotation,使用Annotation进行额外的处理。 Annotation处理器在处理Ann…...

    2024/4/15 18:05:10
  16. ShardingSphere jdbc集成多数据源

    最近有个项目的几张表,数量级在千万以上,技术栈是SpringBoot+Mybatis-plus+MySQL。如果使用单表,在进行查询操作,非常耗时,经过一番调研,决定使用分表中间件:ShardingSphere。 ShardingSphere今年4月份成为了 Apache 软件基金会的顶级项目,目前支持数据分片、读写分离、…...

    2024/4/15 18:05:09
  17. 缓存一致性协议(MESI)详解

    缓存一致性协议是Java内存模型中的一种协议,具体如图所示:缓存一致性协议分为四种状态:Modified(修改):数据有效,数据被修改了,和内存中数据不一致,数据只存在于本Cache中。 Exclusive(独享):数据有效,数据和内存中的数据一致,数据只存在于本Cache中。 Shared(共…...

    2024/4/15 18:05:08
  18. windows下python保存文件名含有‘\’字符的文件

    需求是我想保存一个文件:‘1*1/1\1?1.txt,把所有windows禁止的字符替换成_之前想直接用re.sub,但是不能成功,因为name传进来就\1就被转义为未知符号,而name又是一个变量,我不知道怎么通过r来转义,后来想到可以用str的方法先将\替换掉,然后在用re.sub替换其他字符就可以…...

    2024/4/15 18:05:07
  19. 【题解】LuoGu5689:[CSP-SJX2019]多叉堆

    原题传送门 计数DP并查集维护连通性 令dpudp_udpu​表示以uuu为根的答案 若将vvv连到uuu的下面,则dpu=dpu∗dpv∗Csizeu+sizev−1sizevdp_u=dp_u*dp_v*C_{size_u+size_v-1}^{size_v}dpu​=dpu​∗dpv​∗Csizeu​+sizev​−1sizev​​(因为整棵树中只有根是一定要最小的那个数…...

    2024/4/15 18:05:07
  20. PTA L1-027 出租 (20分)

    L1-027 出租 (20分) 下面是新浪微博上曾经很火的一张图:一时间网上一片求救声,急问这个怎么破。其实这段代码很简单,index数组就是arr数组的下标,index[0]=2 对应 arr[2]=1,index[1]=0 对应 arr[0]=8,index[2]=3 对应 arr[3]=0,以此类推…… 很容易得到电话号码是180138…...

    2024/4/15 18:05:05

最新文章

  1. 海信发布《黑神话:悟空》定制电视E8N新品,重塑大屏游戏体验

    4月17日&#xff0c;在“AI美好生活”2024海信电视E8系列新品发布会上&#xff0c;海信电视官宣成为《黑神话&#xff1a;悟空》全球官方合作伙伴。同时&#xff0c;海信电视还为广大游戏玩家带来了《黑神话&#xff1a;悟空》的显示CP&#xff0c;推出了官方定制电视——旗舰新…...

    2024/4/18 8:22:29
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. javaWeb网上零食销售系统

    1 绪 论 目前&#xff0c;我国的网民数量已经达到7.31亿人&#xff0c;随着互联网购物和互联网支付的普及&#xff0c;使得人类的经济活动进入了一个崭新的时代。淘宝&#xff0c;京东等网络消费平台功能的日益完善&#xff0c;使得人们足不出户就可以得到自己想要的东西。如今…...

    2024/4/17 15:16:52
  4. WPS二次开发专题:WPS SDK实现文档打印功能

    作者持续关注WPS二次开发专题系列&#xff0c;持续为大家带来更多有价值的WPS开发技术细节&#xff0c;如果能够帮助到您&#xff0c;请帮忙来个一键三连&#xff0c;更多问题请联系我&#xff08;QQ:250325397&#xff09; 在办公场景或者家教场景中经常碰到需要对文档进行打印…...

    2024/4/17 19:28:01
  5. 416. 分割等和子集问题(动态规划)

    题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义&#xff1a;dp[i][j]表示当背包容量为j&#xff0c;用前i个物品是否正好可以将背包填满&#xff…...

    2024/4/17 13:33:02
  6. 【Java】ExcelWriter自适应宽度工具类(支持中文)

    工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...

    2024/4/18 8:11:38
  7. Spring cloud负载均衡@LoadBalanced LoadBalancerClient

    LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon&#xff0c;直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件&#xff0c;我们讨论Spring负载均衡以Spring Cloud2020之后版本为主&#xff0c;学习Spring Cloud LoadBalance&#xff0c;暂不讨论Ribbon…...

    2024/4/18 8:11:47
  8. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

    一、背景需求分析 在工业产业园、化工园或生产制造园区中&#xff0c;周界防范意义重大&#xff0c;对园区的安全起到重要的作用。常规的安防方式是采用人员巡查&#xff0c;人力投入成本大而且效率低。周界一旦被破坏或入侵&#xff0c;会影响园区人员和资产安全&#xff0c;…...

    2024/4/18 8:11:56
  9. VB.net WebBrowser网页元素抓取分析方法

    在用WebBrowser编程实现网页操作自动化时&#xff0c;常要分析网页Html&#xff0c;例如网页在加载数据时&#xff0c;常会显示“系统处理中&#xff0c;请稍候..”&#xff0c;我们需要在数据加载完成后才能继续下一步操作&#xff0c;如何抓取这个信息的网页html元素变化&…...

    2024/4/17 23:48:57
  10. 【Objective-C】Objective-C汇总

    方法定义 参考&#xff1a;https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...

    2024/4/18 0:31:55
  11. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

    &#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】&#x1f30f;题目描述&#x1f30f;输入格…...

    2024/4/18 8:12:27
  12. 【ES6.0】- 扩展运算符(...)

    【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数&#xff0…...

    2024/4/17 17:14:39
  13. 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?

    文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕&#xff0c;各大品牌纷纷晒出优异的成绩单&#xff0c;摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称&#xff0c;在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁&#xff0c;多个平台数据都表现出极度异常…...

    2024/4/17 22:55:11
  14. Go语言常用命令详解(二)

    文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令&#xff0c;这些命令可以帮助您在Go开发中进行编译、测试、运行和…...

    2024/4/17 21:16:06
  15. 用欧拉路径判断图同构推出reverse合法性:1116T4

    http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b&#xff0c;我们在 a i a_i ai​ 和 a i 1 a_{i1} ai1​ 之间连边&#xff0c; b b b 同理&#xff0c;则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然&#xff0…...

    2024/4/17 2:08:11
  16. 【NGINX--1】基础知识

    1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息&#xff0c;并安装一些有助于配置官方 NGINX 软件包仓库的软件包&#xff1a; apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...

    2024/4/17 7:27:32
  17. Hive默认分割符、存储格式与数据压缩

    目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限&#xff08;ROW FORMAT&#xff09;配置标准HQL为&#xff1a; ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...

    2024/4/18 3:18:41
  18. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

    文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中&#xff0c;传感器和控制器产生大量周…...

    2024/4/17 8:59:38
  19. --max-old-space-size=8192报错

    vue项目运行时&#xff0c;如果经常运行慢&#xff0c;崩溃停止服务&#xff0c;报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中&#xff0c;通过JavaScript使用内存时只能使用部分内存&#xff08;64位系统&…...

    2024/4/17 16:07:12
  20. 基于深度学习的恶意软件检测

    恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞&#xff0c;例如可以被劫持的合法软件&#xff08;例如浏览器或 Web 应用程序插件&#xff09;中的错误。 恶意软件渗透可能会造成灾难性的后果&#xff0c;包括数据被盗、勒索或网…...

    2024/4/16 15:45:31
  21. JS原型对象prototype

    让我简单的为大家介绍一下原型对象prototype吧&#xff01; 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定&#xff0c;每一个构造函数都有一个 prototype 属性&#xff0c;指向另一个对象&#xff0c;所以我们也称为原型对象…...

    2024/4/17 18:39:29
  22. C++中只能有一个实例的单例类

    C中只能有一个实例的单例类 前面讨论的 President 类很不错&#xff0c;但存在一个缺陷&#xff1a;无法禁止通过实例化多个对象来创建多名总统&#xff1a; President One, Two, Three; 由于复制构造函数是私有的&#xff0c;其中每个对象都是不可复制的&#xff0c;但您的目…...

    2024/4/18 8:12:50
  23. python django 小程序图书借阅源码

    开发工具&#xff1a; PyCharm&#xff0c;mysql5.7&#xff0c;微信开发者工具 技术说明&#xff1a; python django html 小程序 功能介绍&#xff1a; 用户端&#xff1a; 登录注册&#xff08;含授权登录&#xff09; 首页显示搜索图书&#xff0c;轮播图&#xff0…...

    2024/4/17 12:19:01
  24. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

    C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...

    2024/4/18 0:24:11
  25. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  26. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  28. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  29. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  30. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  31. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  32. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  35. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  36. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  37. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  38. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  39. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  40. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  41. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  42. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  43. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  44. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57