pycharm怎么导入数据库_pycharm导入python

pycharm怎么导入数据库_pycharm导入python记录一下自己最近一段时间可能用不上的代码,免得以后再找起来麻烦。pycharm连接数据库首先在找到Database,选择连接自己下载的数据库软件。填写完自己的数据库密码后,如果正确的话,就会出现下面这张图。点下“刷新”按钮后即可连接数据库。测试是否连接成功。到这里基本完成了外部数据导入步骤。2.代码importpymysqlimportmath#用来操作数据库的类classclimb_test_DataInput(object):#…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

记录一下自己最近一段时间可能用不上的代码,免得以后再找起来麻烦。

  1. pycharm连接数据

首先在找到Database,选择连接自己下载的数据库软件。
pycharm怎么导入数据库_pycharm导入python
填写完自己的数据库密码后,如果正确的话,就会出现下面这张图。
点下 “刷新” 按钮后即可连接数据库。
在这里插入图片描述
测试是否连接成功。
在这里插入图片描述
到这里基本完成了外部数据导入步骤。

2. 代码

import pymysql
import math


# 用来操作数据库的类
class climb_test_DataInput(object):
    # 类的初始化
    def __init__(self):
        self.host = 'localhost'
        self.port = 3306  # 端口号
        self.user = '这里填你自己的数据库用户名'  # 用户名
        self.password = "这里填你自己的数据库密码"  # 密码
        self.db = "选择你创建的数据库"  # 库
        self.table = "选择你数据库中的某个表"  # 表

    # 链接数据库
    def connectMysql(self):
        try:
            self.conn = pymysql.connect(host=self.host, port=self.port, user=self.user,
                                        passwd=self.password, db=self.db, charset='utf8')
            self.cursor = self.conn.cursor()
            print('connect mysql successfully.')
        except:
            print('connect mysql error.')

    # 查询数据
    def queryMysql(self):
        goal = "Date,Time,Longitude,Latitude,Altitude,TAS,Heading,x_next,y_next,z_next"
        sql = "SELECT " + goal + " FROM " + self.table

        try:
            self.cursor.execute(sql)
            row = self.cursor.fetchall()
            Date = [x[0] for x in row]
            Time = [x[1] for x in row]
            # Longitude 转化为x
            Longitude = [(x[2] * math.pi * 6378137 / 180) for x in row]
            # Longitude = [x[2] for x in row]

            # Latitude 转化为y
            Latitude = [((math.pi * 6378137 * math.log(math.tan((90 + x[3]) * math.pi / 360)) / (
                    math.pi / 180)) / 180)
                        for x in row]
            # Latitude = [x[3] for x in row]

            # # Longitude 转化为x
            # Longitude = [x[2] * math.pi * 6378137 / 180 for x in row]
            # # Latitude 转化为y
            # Latitude = [(math.pi * 6378137 * math.log(math.tan((90 + x[3]) * math.pi / 360)) / (math.pi / 180)) / 180
            # for x in row]

            Altitude = [x[4] * 0.3048 for x in row]
            TAS = [x[5] for x in row]
            Heading = [x[6] for x in row]

            x_next = [(x[7] * math.pi * 6378137 / 180) for x in row]
            # x_next = [x[9] for x in row]

            y_next = [((math.pi * 6378137 * math.log(math.tan((90 + x[8]) * math.pi / 360)) / (
                    math.pi / 180)) / 180) for x in row]
            # y_next = [x[10] for x in row]

            z_next = [x[9] * 0.3048 for x in row]

            '''转换'''
            # Altitude = Altitude * 0.3048 # 英尺和米转换
            # Longitude = math.pi * 6378137 * Longitude1 / 180
            # Latitude = (math.pi*6378137*math.log(math.tan((90+Latitude1)*math.pi/360))/(math.pi/180))/180
            # print(row)

            print('query mysql successfully.')
            # data = [Longitude, Latitude, Heading, TAS, d, sina, cosa]
            return Date, Time, Longitude, Latitude, Altitude, TAS, Heading, x_next, y_next, z_next
        except:
            print(sql + ' execute failed.')

    def closeMysql(self):
        self.cursor.close()
        self.conn.close()
        print('climb_test_DataInput closed')


climb_test_DataInput = climb_test_DataInput()
climb_test_DataInput.connectMysql()
Date_test, Time_test, Longitude_test, Latitude_test, Altitude_test, TAS_test, Heading_test, x_next_test, y_next_test, z_next_test = climb_test_DataInput.queryMysql()
climb_test_DataInput.closeMysql()

上述为处理数据库中经纬度等位置数据的代码;
当其他文件调用该程序时,只需在其他文件头部添上最后四行代码即可。

3. 注意事项

  1. 当数据库显示无法连接时,请检查电脑中的 MySQL 服务是否打开(我使用的是mysql数据库,以此举例)。
    具体方法是 在cmd窗口中输入 services.msc,在跳出的窗口中找到对应的服务。
  2. 当查询功能出现异常时,请检查自己在 goal 中写入的表名是否正确。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/175309.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • python贪吃蛇游戏代码详解外加中文_Python贪吃蛇代码

    python贪吃蛇游戏代码详解外加中文_Python贪吃蛇代码#!/usr/bin/envpythonimportpygame,sys,time,randomfrompygame.localsimport*#定义颜色变量redColour=pygame.Color(255,0,0)blackColour=pygame.Color(0,0,0)whiteColour=pygame.Color(255,255,255)greyColour…

    2022年8月10日
    13
  • Linux系统开启IPv6任播(anycast)地址[通俗易懂]

    Linux系统开启IPv6任播(anycast)地址[通俗易懂]这两年真是在linux上各种掏捡,各种零碎。。。无力吐槽了。。。下面简单记录一下开启任播地址我的系统是Debian7.21、开启IPv6转发sudoecho1>/proc/sys/net/ipv6/conf/all/forwarding2、完了系统会自动生成IPv6任播地址cat/proc/net/anycast6此时你在网卡上新配置一个IPv6地址,就会在/proc/net/anycast6下生成一个对应的任播地址。在另一台主机上你可以ping6一下其中一个任.

    2022年5月23日
    56
  • express根据token获取用户id「建议收藏」

    //登陆时注册tokendb.query(`select*fromuserwherename=${username}andpassword=’${password}’`,(result)=>{if(result.length==1){ //jwt.sign({userId:result[0].id}在注册的时候加入用户id…

    2022年4月14日
    227
  • APK签名原理

    APK签名原理网上已有多篇分析签名的类似文章,但是都有一个共同的问题,就是概念混乱,混乱的一塌糊涂。在了解APK签名原理之前,首先澄清几个概念:消息摘要-MessageDigest简称摘要,请看英文翻译,是摘要,不是签名,网上几乎所有android签名分析的文章都对这两个概念乱用摘要的链接http://en.wikipedia.org/wiki/Message_digest简

    2022年6月12日
    30
  • 双边滤波加速「建议收藏」

    双边滤波器是同时考虑空间域和值域信息的类似传统高斯平滑滤波器的图像滤波、去噪、保边滤波器。其模板系数是空间系数d与值域系数r的乘积。其思想是:空间系数是高斯滤波器系数,值域系数为考虑了邻域像素点与中心像素点的像素值的差值,当差值较大时,值域系数r较小,即,为一个递减函数(高斯函数正半部分),带来的结果是总的系数w=d*r变小,降低了与“我”差异较大的像素对我的影响。从而达到保边的效果,同时

    2022年4月16日
    67

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号