RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题

全部问题

Martin Hope
iod131
Asked: 2024-08-28 05:17:25 +0000 UTC

如何在使用 babel 包俄化的 LaTeX 文档中的某些位置插入中文字符?

  • 6

我需要在文档文本中的大约五个位置插入几个象形文字,该文档通过包进行俄罗斯化babel。

例如:

\documentclass[oneside, final, 14pt]{extbook}
\usepackage[utf8]{inputenc}
\usepackage[russian]{babel}
\usepackage{vmargin}
\setpapersize{A4}
\usepackage{indentfirst}
\sloppy

\begin{document}

中~--- это иероглиф, означающий <<середина>>.

\end{document}

广播时,pdflatex 输出:

! LaTeX 错误:Unicode 字符 中 (U+4E2D) 未设置用于 LaTeX。

在这种情况下如何正确插入象形文字? *.tex 文件编码 UTF8,分布Debian GNU/Linux 12 (bookworm) x86_64.

latex
  • 1 个回答
  • 34 Views
Martin Hope
Fox Fox
Asked: 2024-08-28 03:14:18 +0000 UTC

Python:计算往返另一个恒星系统的飞行参数

  • 13

根据 Stanislav Volodarsky 的计算(见下文),我们似乎能够建立一定的理论并编写计算脚本:

'''
Задача: экспедиция стартует из Солнечной системы в другую звёздную систему с постоянным ускорением. Первую часть пути корабль ускоряется,
вторую часть пути летит по инерции, третью часть пути тормозится (с тем же ускорением, но отрицательным, и на таком же участке пути).
К моменту прибытия в другую звёздную систему скорость корабля равна 0. Далее - путь домой, точно по такой же схеме.
Вычислить время полёта туда и обратно в земной системе отсчёта, время полёта туда и обратно в системе отсчёта корабля, максимальную скорость корабля.
'''

import os
import math

print("-" * 65 + "\nРасчёт параметров полёта в другую звёздную систему и обратно:\n" + "-" * 65)

c = 1  # скорость света: 1 световой год / год
a = 2  # ускорение корабля: 1 световой год / год ** 2 = 9,5 м / c ** 2 (близко к значению ускорения свободного падения на поверхности Земли)
star = "Фомальгаут"
l = 25  # расстояние до звёздной системы (световых лет)
l_a = l * 0.1  # расстояние, пройденное в режиме разгона (торможения) в одну сторону (световых лет)
l_i = l * 0.8  # расстояние, пройденное в режиме движения по инерции  в одну сторону (световых лет)

# время разгона (торможения) в одну сторону в земной системе отсчёта (лет)
t1 = c / a * math.sqrt((a * l_a / c ** 2 + 1) ** 2 - 1)

# время разгона (торможения) в одну сторону в системе отсчёта корабля (лет)
t2 = c / a * math.log(math.sqrt(1 + (a * t1 / c) ** 2) + a * t1 / c)

# максимальная скорость корабля, которую удалось достичь (долей скорости света)
v = a * t1 / math.sqrt(1 + (a * t1 / c) ** 2)

# время движения по инерции в одну сторону в земной системе отсчёта (лет)
t1_i = l_i / v

# время движения по инерции в одну сторону в системе отсчёта корабля (лет)
t2_i = t1_i * math.sqrt(1 - (v / c) ** 2)

# общее время полёта в земной системе отсчёта (лет)
t1_full = 4 * t1 + 2 * t1_i

# общее время полёта в системе отсчёта корабля (лет)
t2_full = 4 * t2 + 2 * t2_i

# Вывод результатов
print(f"Звёздная система: {star}")
print(f"Расстояние до звёздной системы (световых лет): {l: .2f}")
print(f"Ускорение корабля (световых лет / (год ** 2)): {a: .2f}")
print(f"Расстояние, пройденное в режиме разгона (торможения) туда и обратно (в %): {4 * l_a / l: .2%}")
print(f"Расстояние, пройденное в режиме движения по инерции туда и обратно (в %): {2 * l_i / l: .2%}")
print(f"Время полёта туда и обратно в земной системе отсчёта (лет): {t1_full: .2f}")
print(f"Время полёта туда и обратно в системе отсчёта корабля (лет): {t2_full: .2f}")
print(f"Максимальная скорость корабля (% от скорости света): {v: .2%}")

print("\nНажмите любую клавишу для продолжения...")
os.system("pause > nul")

结果如下:

-----------------------------------------------------------------
Расчёт параметров полёта в другую звёздную систему и обратно:
-----------------------------------------------------------------
Звёздная система: Фомальгаут
Расстояние до звёздной системы (световых лет):  25.00
Ускорение корабля (световых лет / (год ** 2)):  2.00
Расстояние, пройденное в режиме разгона (торможения) туда и обратно (в %):  40.00%
Расстояние, пройденное в режиме движения по инерции туда и обратно (в %):  160.00%
Время полёта туда и обратно в земной системе отсчёта (лет):  52.40
Время полёта туда и обратно в системе отсчёта корабля (лет):  11.72
Максимальная скорость корабля (% от скорости света):  98.60%
python
  • 2 个回答
  • 133 Views
Martin Hope
Dezmonder
Asked: 2024-08-27 23:50:43 +0000 UTC

优化 True-False 标志

  • 6

问题

在我的代码中,为了方便起见,我使用以下构造来更改标志的状态,无论其当前状态如何:

flag *= -1

这个设计相当方便,唯一的缺点是我不喜欢它的验证方式:

if flag == 1:
    print('True')

检查 True - False 标志肯定看起来要好得多:

if flag:
    print('True')

然而这样的flag的状态转换设计却让我眼睛流血:

if flag:
    flag = False
else:
    flag = True

我想收集这些选项中最好的:

  1. 无条件验证的可能性
  2. 能够替换一行(简单)中的值

我想到了什么选择:

方法一:类

最符合逻辑和 Pythonic 的方法是使用类。至少,我得到了这样的东西:

class Flag():
    def __init__(self, val:bool):
        self.val = val
    def __bool__(self):
        return self.val

    def switch(self):
        if self.val:
            self.val = False
        else:
            self.val = True

它甚至可以工作,但问题是这个类调用起来很不方便:

我们应该flag = True这样做flag = Flag(True)。当我忘记注册这个类,或者尝试从不属于我的方法获取标志值时,在最意想不到的时刻,什么会像契诃夫的枪一样爆炸。

方法2:将标志塞到某处

实际上,这个想法类似于类:

def switch(dct: dict):
    if dct['val']:
        dct['val'] = False
    else:
        dct['val'] = True

缺点:您知道如何存储和检查它吗?我想,这尽可能不方便

方法三:记住退货

def switch(val):
    if val:
        return False
    else:
        return True

my_flag = True
print(my_flag)
my_flag = switch(my_flag)
print(my_flag)

总体来说还可以,但还是不太喜欢这个设计my_flag = switch(my_flag)。

其实问题是:

您认为存储和切换标志的最佳方式是什么?很可能有一些非常简单的东西可以做我想要的事情,但没有立即找到这样的方法。

哦,是的,这个问题纯粹是理论上的,甚至是关于“赏心悦目的”,但总的来说,我希望本质是清楚的

python
  • 2 个回答
  • 41 Views
Martin Hope
Dato Dato
Asked: 2024-08-27 21:08:36 +0000 UTC

如何在电报机器人中向数据库添加两条消息?

  • 5

如何将信息添加到电报机器人的数据库中?我想向与数据库配合使用的测试机器人添加一个字典功能,例如,在本例中,它向数据库添加信息。也就是说,该功能的顺序如下 - 单击“词典”按钮,输入电报中的第一个句子,然后输入第二个句子,这些句子将记录在数据库中。为此,我添加了函数 connect_to_db、insert_data、dictionary_message、dictionary_message_step_2:

import psycopg2
import telebot
from telebot import types
from telebot.types import Message
from googletrans import Translator
from langdetect import detect
TOKEN='...'
bot = telebot.TeleBot(TOKEN)
translator = Translator()
ru_letters = "абвгдеёжзийклмнопрстуфхцчшщъыьэюя"
en_letters = "abcdefghijklmnopqrstuvwxyz"
DATABASE_URL = "postgres://..."
@bot.message_handler(commands=['start'])
def start(message):
    message_user = f"Привет, <b>{message.from_user.first_name.title()}</b>! Я тестовый бот.\n" \
                   f"<b>Выбери программу, которую ты хочешь выполнить:</b>\n" \
                   f"1. Чем полезен данный бот\n" \
                   f"2. Функции бота (что может данный бот)\n" \
                   f"3. Для тех кто хочет поддержать нас и наш проект"
    markup = types.ReplyKeyboardMarkup(resize_keyboard=True)
    item1 = types.KeyboardButton(text="Чем полезен бот ?")
    item2 = types.KeyboardButton(text="Функции бота")
    item3 = types.KeyboardButton(text="Поддержать проект")
    markup.add(item1, item2, item3)
    bot.send_message(message.from_user.id, message_user, reply_markup=markup, parse_mode='html')
    bot.register_next_step_handler(message, impact_KEYBORD_bot)
    bot.register_next_step_handler(message, fuctional_KEYBORD_bot)
    bot.register_next_step_handler(message, donat_user_bot)
def impact_KEYBORD_bot(message):
    if message.text == "Чем полезен бот ?":
        message_user = "Этот бот много чем будет полезен для вас. Ознакомьтесь с функционалом бота чтобы понять это." \
                       " В этого бота со временем мы будем внедрять новые фичи и полезные функции. Чтобы узнавать о новых фишках бота, слидите за нашим Telegramm каналом"
        key = types.InlineKeyboardMarkup()
        button = types.InlineKeyboardButton(text='Мое портфолио', url="http://dato138it.ru")
        key.add(button)
        bot.send_message(message.from_user.id, message_user, reply_markup=key, parse_mode='html')
        bot.register_next_step_handler(message, fuctional_KEYBORD_bot)
        bot.register_next_step_handler(message, donat_user_bot)
def fuctional_KEYBORD_bot(message):
    if message.text == 'Функции бота':
        message_user = "<b>Добро пожаловать главное меню бота</b>\n\n" \
                       "В скором будущем мы будем добавлять сюда новые функции!"
        key = types.ReplyKeyboardMarkup(resize_keyboard=True)
        button0 = types.KeyboardButton("Переводчик")
        button1 = types.KeyboardButton("Словарь")
        key.add(button0, button1)
        bot.send_message(message.from_user.id, message_user, reply_markup=key, parse_mode='html')
        bot.register_next_step_handler(message, impact_KEYBORD_bot)
        bot.register_next_step_handler(message, donat_user_bot)
        bot.register_next_step_handler(message, translate_message)
        #bot.register_next_step_handler(message, dictionary_message)
def donat_user_bot(message):
    if message.text == "Поддержать проект":
        message_users = f"<b>Приветствую  уважаемый {message.from_user.first_name.title()}</b>, вы перешли в отдел поддержки нашего проекта \n\n" \
                        f"Мы будем благодарны любой поддержки от вас. И также благодарим, что вы пользуетесь нашим ботом - это главная ваша поддержка для нас!\n\n" \
                        f"Мы принимаем материальную поддержку на:\n" \
                        f"<b>1. Donationalerts</b>\n" \
                        f"<b>2. PAYEER</b>\nномер счёта для пополнения: P1091200672\n" \
                        f"<b>3. QIWI</b>\n" \
                        f"<b>4. Тинькофф банк</b>"
        key = types.InlineKeyboardMarkup()
        button0 = types.InlineKeyboardButton(text="Donationalerts", url="https://ССЫЛКА_НА_ДОНАТ")
        button1 = types.InlineKeyboardButton(text="PAYEER", url="https://ССЫЛКА_НА_КОШЕЛЕК")
        button2 = types.InlineKeyboardButton(text="QIWI", url="https://ССЫЛКА_НА_КИВИ")
        button3 = types.InlineKeyboardButton(text="Тинькофф банк", url="https://ССЫЛКА_НА_БАНК")
        key.add(button0, button1, button2, button3)
        bot.send_message(message.from_user.id, message_users, reply_markup=key, parse_mode='html')
        bot.register_next_step_handler(message, impact_KEYBORD_bot)
        bot.register_next_step_handler(message, fuctional_KEYBORD_bot)
@bot.message_handler(content_types=['text'])
def translate_message(message):
    if message.text == 'Переводчик':
        bot.send_message(message.chat.id, 'Напишите сообщения а я переведу его')
        bot.register_next_step_handler(message, translate_message_step_2)
    elif message.text == 'Словарь':
        bot.send_message(message.chat.id, 'Напишите 2 предлоежения, которые нужно добавить в базу')
        bot.register_next_step_handler(message, dictionary_message_step_2)
def translate_message_step_2(message):
    cmd3 = message.text
    if cmd3[0].lower() in ru_letters:
        translation = translator.translate(cmd3, src=detect(cmd3), dest='en').text
        bot.send_message(message.chat.id, translation.encode('utf-8', 'replace').decode())
    elif cmd3[0].lower() in en_letters:
        translation = translator.translate(cmd3, src=detect(cmd3), dest='ru').text
        bot.send_message(message.chat.id, translation.encode('utf-8', 'replace').decode())
    else:
        bot.send_message(message.chat.id, 'Я тебя не понимаю')
def connect_to_db():
    conn = psycopg2.connect(DATABASE_URL, sslmode='require')
    return conn
def insert_data(words, translate):
    conn = connect_to_db()
    cursor = conn.cursor()
    query = "INSERT INTO Dictionary (words, translate) VALUES (%s, %s)"
    cursor.execute(query, (words, translate))
    conn.commit()
    cursor.close()
    conn.close()
#def dictionary_message(message):
    #if message.text == 'TEST':
    #bot.send_message(message.chat.id, 'Напишите 2 предлоежения, которые нужно добавить в базу')
        #bot.register_next_step_handler(message, dictionary_message_step_2)
def dictionary_message_step_2(message):
    bot.send_message(message.chat.id, '1-ое предложение: ')
    cmd4 = message.text
    bot.send_message(message.chat.id, '2-ое предложение: ')    
    cmd5 = message.text
    #insert_data(cmd4, cmd5)
    bot.reply_to(message, "Add Info in Dictionary.")
if __name__ == '__main__':
    bot.polling(none_stop=True, interval=0)

但由于某种原因,首先,它只对“词典”按钮做出一次反应,下次您只需重新启动它,其次,机器人仅将第一个句子保存到数据库中,由于某种原因,它看不到第二个句子。

python
  • 1 个回答
  • 31 Views
Martin Hope
Ikanamaya
Asked: 2024-08-27 18:37:18 +0000 UTC

我不明白Unity中的TransformDirection

  • 5

假设我们在场景的零坐标中有一个立方体。我更改其位置,使其向前移动 10 个单位:

transform.position = new Vector3(x, y, 10);

当我将立方体旋转 45 度并再次沿 z 轴移动 10 个单位时,它将相对于场景坐标(即全局坐标)以相同的方式移动,它不会沿 z 方向移动。然而,使用 TransformDirection 意味着将向量值从局部转换为全局:

Vector3 direction = new Vector3(x, y, z);
Vector3 worldDirection = transform.TransformDirection(direction);
transform.position += worldDirection;

现在,如果我将立方体旋转 45 度,那么它已经相对于其 z 轴移动,那么逻辑是什么?事实恰恰相反,如果我不使用 TransfromDirection,那么对象本身默认会沿着全局 z 轴移动,而使用 TransfromDirection 则相反,会让对象沿着自己的坐标移动。请澄清我的困惑,因为我在互联网上没有找到这种方法的合理解释。

c#
  • 1 个回答
  • 47 Views
上一页
下一页

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5