欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python如何下載指定版本TensorFlow

 更新時(shí)間:2024年03月28日 08:37:25   作者:灬點(diǎn)點(diǎn)  
這篇文章主要介紹了python如何下載指定版本TensorFlow問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

一、python安裝與下載依賴

依賴版本

TensorFlow>=2.3.0
Keras  >= 2.4.3 
Numpy < 1.19.0
Pandas >= 1.1.0
scikit-learn >= 0.23.2
librosa >=0.8.0
scipy==1.4.1

依賴下載

TensorFlow>=2.3.0 pip3 install tensorflow-cpu==2.3.0 -i https://pypi.douban.com/simple/
Keras >= 2.4.3 pip3 install Keras==2.4.3 -i https://pypi.douban.com/simple/
Pandas >= 1.1.0 pip3 install Pandas==1.1.0 -i https://pypi.douban.com/simple/
scikit-learn >= 0.23.2 pip3 install scikit-learn==0.23.2 -i https://pypi.douban.com/simple/
librosa >=1.19.1 pip3 install librosa==0.8.0 -i https://pypi.douban.com/simple/
scipy==1.4.1 pip3 install scipy==1.4.1 -i https://pypi.douban.com/simple/ 

安裝python3

yum -y install gcc
yum -y install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel libffi-devel
wget https://www.python.org/ftp/python/3.7.3/Python-3.7.3.tgz
tar -zxvf Python-3.7.3.tgz
mkdir /usr/local/python3
cd Python-3.7.3
./configure --prefix=/usr/local/python3
make && make install
ln -sf /usr/local/python3/bin/python3.7 /usr/bin/python3
ln -sf /usr/local/python3/bin/pip3.7 /usr/bin/pip3

驗(yàn)證

pip3 list

pip3升級(jí)

pip3 --default-timeout=10000 install -U pip

pip3 卸載與安裝

  • pip3 install 包名 例如:pip3 install Pandas
  • pip3 uninstall 包名 例如: pip3 uninstall Pandas

二、mybatis plus 樂觀鎖配置

import com.baomidou.mybatisplus.extension.plugins.OptimisticLockerInterceptor;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.transaction.annotation.EnableTransactionManagement;

/**
 * mybatis plus 樂觀鎖配置
 * @author nick
 */
@EnableTransactionManagement
@Configuration
public class MybatisPlusConfig {
    /**
     *   樂觀鎖
     */
    @Bean
    public OptimisticLockerInterceptor optimisticLockerInterceptor() {
        return new OptimisticLockerInterceptor();
    }
}

三、@Scheduled定時(shí)任務(wù)升級(jí)分布式定時(shí)任務(wù)

/**
 * DisSchedule切面
 */
@Order(100)
@Aspect
@Slf4j
public class DisScheduleAspect {

	public static final String SERVER_NAME = "serverName";

	private final IDisScheduleService disScheduleService;

	private final String serverName;

	public DisScheduleAspect(
		IDisScheduleService disScheduleService,
		Environment environment) {
		Preconditions.checkNotNull(disScheduleService);
		this.disScheduleService = disScheduleService;
		Preconditions.checkNotNull(environment);
		String serverName = environment.getProperty(SERVER_NAME);
		Preconditions.checkArgument(!Strings.isNullOrEmpty(serverName));
		this.serverName = serverName;
	}

	/**
	 * 方法上有注解SaveLog
	 */
	@Pointcut(value = "@annotation(com.citydo.xclouddesk.interceptor.annotation.DisSchedule)")
	public void disScheduleAnnotation() {
	}

	@Around(value = "disScheduleAnnotation() && @annotation(disSchedule)")
	public Object disSchedule(ProceedingJoinPoint joinPoint, DisSchedule disSchedule) throws Throwable {
		Preconditions.checkNotNull(disSchedule);
		// 當(dāng)前時(shí)間
		Date curDate = TimeUtil.getCurDate();
		// 獲取name
		String name = disSchedule.name();
		if (Strings.isNullOrEmpty(name)) {
			// 方法名
			Signature signature = joinPoint.getSignature();
			name = signature.getName();
		}
		// 時(shí)間間隔
		int duration = disSchedule.duration();
		if (duration <= 0) {
			log.error(
				"disSchedule fail, duration {} is less or equal 0, name : {}",
				duration,
				name
			);
			return null;
		}
		// 時(shí)間間隔的單位
		TimeUnit unit = disSchedule.unit().getUnit();
		// 轉(zhuǎn)化為毫秒
		long millis = unit.toMillis(duration);
		// 獲取當(dāng)前任務(wù)所屬的開始時(shí)間
		Date taskDate = TimeUtil.getMillisDate(curDate, (int) millis);
		// 當(dāng)前服務(wù)是否屬于線上服務(wù)
		if (!disScheduleService.serverNameIsValid(serverName)) {
			log.info(
				"disSchedule fail, serverName is invalid, serverName : {} , name : {} , taskDate : {}",
				serverName,
				name,
				TimeUtil.specialFormatToDateStr(taskDate)
			);
			return null;
		}
		if (!disScheduleService.tryGetLock(name, taskDate, serverName)) {
			log.info(
				"Distributed lock not acquired, name : {} , taskDate : {}",
				name,
				TimeUtil.specialFormatToDateStr(taskDate)
			);
			return null;
		}
		// 執(zhí)行正常的方法邏輯
		return joinPoint.proceed();
	}
}
/**
 * 在方法執(zhí)行之前,決定當(dāng)前是否需要執(zhí)行定時(shí)調(diào)度任務(wù)
 * @author nick
 */
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface DisSchedule {

	/**
	 * 定時(shí)調(diào)度任務(wù)的名稱(默認(rèn)是方法名)
	 */
	String name() default "";

	/**
	 * 任務(wù)的間隔時(shí)間
	 */
	int duration();

	/**
	 * duration的時(shí)間單位(默認(rèn):分鐘)
	 */
	DisScheduleUnit unit() default DisScheduleUnit.MINUTES;
}
/**
 * 分布式定時(shí)調(diào)度服務(wù)
 * @author nick
 */
public interface IDisScheduleService {

	/**
	 * 重新加載
	 */
	void reload();

	/**
	 * serverName是否有效
	 */
	boolean serverNameIsValid(String serverName);

	/**
	 * 嘗試獲取鎖
	 */
	boolean tryGetLock(String taskName, Date taskDate, String serverName);

	/**
	 * 添加當(dāng)前的serverName
	 */
	void addServerName(String serverName);

	/**
	 * 移除當(dāng)前的serverName
	 */
	void removeServerName(String serverName);
}

/**
 * redis實(shí)現(xiàn)
 */
@Slf4j
@Service
public class DisScheduleRedisServiceImpl implements IDisScheduleService {

	public static final String DIS_SCHEDULE_SERVER_NAME = "disScheduleServerName";

	private final IRedisManager redisManager;

	public DisScheduleRedisServiceImpl(IRedisManager redisManager) {
		Preconditions.checkNotNull(redisManager);
		this.redisManager = redisManager;
	}

	@Override
	public void reload() {
		// do nothing
	}

	@Override
	public boolean serverNameIsValid(String serverName) {
		try {
			return redisManager.isMember(DIS_SCHEDULE_SERVER_NAME, serverName);
		} catch (Exception e) {
			log.error(
				"DisScheduleRedisServiceImpl-serverNameIsValid fail, serverName : {} , exception : {}",
				serverName,
				e
			);
		}
		return false;
	}

	@Override
	public boolean tryGetLock(String taskName, Date taskDate, String serverName) {
		try {
			return redisManager.setNx(
				taskName + "_" + TimeUtil.specialFormatToDateStr(taskDate),
				serverName
			);
		} catch (Exception e) {
			log.error(
				"DisScheduleRedisServiceImpl-tryGetLock fail, taskName : {} , taskDate : {} , serverName : {} , exception : {}",
				taskName,
				TimeUtil.specialFormatToDateStr(taskDate),
				serverName,
				e
			);
		}

		return false;
	}

	@Override
	public void addServerName(String serverName) {
		Preconditions.checkArgument(!Strings.isNullOrEmpty(serverName));
		redisManager.sAdd(DIS_SCHEDULE_SERVER_NAME, serverName);
	}

	@Override
	public void removeServerName(String serverName) {
		Preconditions.checkArgument(!Strings.isNullOrEmpty(serverName));
		redisManager.sRem(DIS_SCHEDULE_SERVER_NAME, serverName);
	}


//  @DisSchedule(name = "testSchedule", duration = 1, unit = DisScheduleUnit.MINUTES)
//  @Scheduled(cron = "0 0/1 * * * ?")
//  public void testSchedule() {
//	logger.info("輸出");
//  }
}
public interface IRedisManager {


	/**
	 * 向set中添加元素
	 */
	boolean sAdd(String key, String value);

	/**
	 * set中是否存在value
	 */
	boolean isMember(String key, String value);

	/**
	 * 移除set中的元素
	 */
	void sRem(String key, String value);


	/**
	 * 設(shè)置字符串的值(如果不存在的話)
	 */
	boolean setNx(String key, String value);
}
/**
 * 基于jedis實(shí)現(xiàn)的redisManager
 */
@Service
public class JedisManagerImpl implements IRedisManager {

	@Autowired
	private JedisPoolClient jedisPoolClient;

	/**
	 * 返回1說明添加成功,返回0說明已經(jīng)存在
	 * @param key
	 * @param value
	 * @return
	 */
	@Override
	public boolean sAdd(String key, String value) {
		Preconditions.checkArgument(!Strings.isNullOrEmpty(key));
		Preconditions.checkArgument(!Strings.isNullOrEmpty(value));
		return jedisPoolClient.sAdd(key, value) == 1L;
	}

	@Override
	public boolean isMember(String key, String value) {
		Preconditions.checkArgument(!Strings.isNullOrEmpty(key));
		Preconditions.checkArgument(!Strings.isNullOrEmpty(value));
		return jedisPoolClient.isMember(key, value);
	}

	@Override
	public void sRem(String key, String value) {
		Preconditions.checkArgument(!Strings.isNullOrEmpty(key));
		Preconditions.checkArgument(!Strings.isNullOrEmpty(value));
		jedisPoolClient.sRem(key, value);
	}

	@Override
	public boolean setNx(String key, String value) {
		Preconditions.checkArgument(!Strings.isNullOrEmpty(key));
		Preconditions.checkArgument(!Strings.isNullOrEmpty(value));
		return jedisPoolClient.setNX(key, value);
	}
}

參考:https://github.com/death00/dis-schedule

四、Multiset與HashMap、Multimap關(guān)系

在這里插入圖片描述

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 用python代碼將tiff圖片存儲(chǔ)到j(luò)pg的方法

    用python代碼將tiff圖片存儲(chǔ)到j(luò)pg的方法

    今天小編就為大家分享一篇用python代碼將tiff圖片存儲(chǔ)到j(luò)pg的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧
    2018-12-12
  • ubuntu 安裝pyqt5和卸載pyQt5的方法

    ubuntu 安裝pyqt5和卸載pyQt5的方法

    這篇文章主要介紹了ubuntu 安裝pyqt5和卸載pyQt5的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • Pygame框架實(shí)現(xiàn)飛機(jī)大戰(zhàn)

    Pygame框架實(shí)現(xiàn)飛機(jī)大戰(zhàn)

    這篇文章主要為大家詳細(xì)介紹了Pygame框架實(shí)現(xiàn)飛機(jī)大戰(zhàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • 解讀時(shí)間序列分析之ADF檢驗(yàn)

    解讀時(shí)間序列分析之ADF檢驗(yàn)

    這篇文章主要介紹了解讀時(shí)間序列分析之ADF檢驗(yàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • 利用Python實(shí)現(xiàn)定時(shí)程序的方法

    利用Python實(shí)現(xiàn)定時(shí)程序的方法

    在 Python 中,如何定義一個(gè)定時(shí)器函數(shù)呢?本文主要介紹了2種方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • 深入探究Python中的迭代器和生成器

    深入探究Python中的迭代器和生成器

    迭代器(Iterators)和生成器(Generators)是?Python?中最強(qiáng)大的功能之一,但也是新手最容易混淆的部分,本文將深入探討這兩種概念,以及它們?cè)?Python?編程中的實(shí)際應(yīng)用,需要的朋友可以參考下
    2023-06-06
  • 一文帶你吃透Python中的日期時(shí)間模塊

    一文帶你吃透Python中的日期時(shí)間模塊

    Python?提供了?日期和時(shí)間模塊用來(lái)處理日期和時(shí)間,還可以用于格式化日期和時(shí)間等常見功能。這篇文章就來(lái)帶大家了解一下它的使用,需要的可以參考一下
    2023-02-02
  • 我對(duì)PyTorch dataloader里的shuffle=True的理解

    我對(duì)PyTorch dataloader里的shuffle=True的理解

    這篇文章主要介紹了我對(duì)PyTorch dataloader里的shuffle=True的理解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-05-05
  • Python如何按單元格讀取復(fù)雜電子表格(Excel)的數(shù)據(jù)

    Python如何按單元格讀取復(fù)雜電子表格(Excel)的數(shù)據(jù)

    這篇文章主要介紹了Python如何按單元格讀取復(fù)雜電子表格(Excel)的數(shù)據(jù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • 詳解Django CAS 解決方案

    詳解Django CAS 解決方案

    這篇文章主要介紹了詳解Django CAS 解決方案,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10

最新評(píng)論