172 похожих чатов

Вот адаптация под питон use pyo3::{wrap_pyfunction, prelude::*}; use calamine::{open_workbook_auto, DataType, Range, Reader}; use

std::fs::File;
use std::io::{BufWriter, Write};
use std::path::PathBuf;
/// Formats the sum of two numbers as string.
/// A Python module implemented in Rust.
#[pymodule]
fn xlsx2csv(_py: Python, m: &PyModule) -> PyResult<()> {
m.add_function(wrap_pyfunction!(make_csv, m)?)?;
Ok(())
}
#[pyfunction]
fn make_csv(py: Python, file: String, separator: Option<String>)-> PyResult<&PyAny> {
println!("Создаём файлы");
//Первый файл
let sce = PathBuf::from(&file);
match sce.extension().and_then(|s: &std::ffi::OsStr| s.to_str()) {
Some("xlsx") | Some("xlsm") | Some("xlsb") | Some("xls") => (),
_ => panic!("Expecting an excel file"),
}

let dest: PathBuf = sce.with_extension("csv");
let mut dest = BufWriter::new(File::create(dest).unwrap());
let mut xl = open_workbook_auto(&file).unwrap();
let range = xl.worksheet_range_at(0).unwrap().unwrap();
let sep = separator.unwrap_or(','.to_string());
let locals = pyo3_asyncio::TaskLocals::with_running_loop(py)?.copy_context(py)?;
return pyo3_asyncio::tokio::future_into_py_with_locals(py, locals.clone(), write_range(&mut dest, range.clone(), sep));
}

async fn write_range<W: Write>(dest: &mut W, range: Range<DataType>, separator: String) -> Result<(), PyErr> {
let n = range.get_size().1 - 1;
for r in range.rows() {
for (i, c) in r.iter().enumerate() {
match *c {
DataType::Empty => Ok(()),
DataType::String(ref s) | DataType::DateTimeIso(ref s) | DataType::DurationIso(ref s) => {
write!(dest, "{}", s)
}
DataType::DateTime(ref s) | DataType::Duration(ref s) => {write!(dest, "{}", s.to_string())}
DataType::Float(ref f) => {
write!(dest, "{}", f)
}

DataType::Int(ref i) => write!(dest, "{}", i),
DataType::Error(ref e) => write!(dest, "{:?}", e),
DataType::Bool(ref b) => write!(dest, "{}", b),
}?;
if i != n {
write!(dest, "{}", separator)?;
}
}
write!(dest, "\r\n")?;
}
Ok(())
}

14 ответов

44 просмотра

А что в функции write_range асинхронного, кроме ключевого слова async? Ты знаешь, как он работает?

krakotay- Автор вопроса
Alexander Karaev
А что в функции write_range асинхронного, кроме кл...

Скажу честно, я плохо представляю, как работают асинхронные функции. Но в версии для rust или ноды синхронная версия кода работает гораздо медленнее

krakotay- Автор вопроса
krakotay
Скажу честно, я плохо представляю, как работают ас...

Возможно, стоит разобраться, а уже потом писать статьи на хабр?

krakotay- Автор вопроса
Alexander Karaev
Возможно, стоит разобраться, а уже потом писать ст...

Возможно. Ну так что? Асинхронная версия работает быстрее. Чего ещё нужно?)

krakotay
Возможно. Ну так что? Асинхронная версия работает ...

Нет, асинхронная не будет работает быстрее только потому что она асинхронная

krakotay- Автор вопроса
Alexander Karaev
Нет, асинхронная не будет работает быстрее только ...

Я, естественно, говорил не про абстрактный пример, а про свой

Alexander Karaev
Нет, асинхронная не будет работает быстрее только ...

Ну у него же работает. Какие вопросы? Реальность первичнее теории

krakotay- Автор вопроса
krakotay
Я, естественно, говорил не про абстрактный пример,...

Что, кстати, не отменяет того, что ты абсолютно прав

krakotay- Автор вопроса
Nano
Ну у него же работает. Какие вопросы? Реальность п...

Напомнило. Согласно теории, теория и практика совпадают, но на практике это не так

Nano
Ну у него же работает. Какие вопросы? Реальность п...

Судя по сказанному ранее, оно ещё даже не скомпилировалось, чтобы работать. И смотря на код async функции без единого await'а внутри, я сильно сомневаюсь в истинности утверждения про "быстрее"

krakotay- Автор вопроса
krakotay
Возможно. Ну так что? Асинхронная версия работает ...

Синхронный код всегда быстрее асинхронного, кроме случаев когда синхронный код позволяет себе ждать результатов IO вместо того чтобы заняться чем-нибудь полезнее.

krakotay- Автор вопроса
Alexander Ruliov
Синхронный код всегда быстрее асинхронного, кроме ...

вот оно как, спасибо за совет. Судя по всему, я фатально ошибся с тестированием программы, из-за чего возникло ложное представление о силе синхронного кода

Похожие вопросы

Обсуждают сегодня

а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Привет всем. Подскажите где можно посмотреть, какая версия электрон, поддерживает версии windows? Некий changelog. Мне бы желательно, поддержку 7,8,10... latest, как понимаю и...
Anonym Squad
21
Портфолио: Зовут меня Александр, мне 36 лет. Город Пушкино. Общий рабочий стаж: ~14 лет Уровень квалификации: Senior Full-stack developer Где прочесть мой код? https://github....
Magic
10
Не ну фпц - это уже просто троллинг какой-то. Элементарный код нельзя собрать. ЧЯДНТ? program Project1; {$mode delphi} uses SysUtils, Classes, Generics.Collections; var...
Peter
4
а где есть mysql cloud кроме яндекс-клауд?
Oleg Nosov
13
Есть ли смысл устраиваться на 1с ? Даст это плюс в дальнейшем трудоустройстве на php? Просто у меня в городе вакансий на пхп нету. Или лучше удаленно искать. Опыта работы нету...
Azamat
14
hi im a cs student. i need some advice from people who have enough experience in Embedded Software. I need to know whether this profession is suitable for me. I have watched s...
Sahand 🏔️
8
А кто-нибудь запихивал сборку перловых модулей/образов с perl приложениями в окружения без интернета (в специализированном CI/CD)? У меня сейчас есть ряд cpanfile, которые н...
Andrey Smirnov / 𝓪𝓵𝓵𝓽𝓮𝓻 /
14
Кстати а покупал кто-нибудь ЭЦП для подписи кода? А то у меня на некоторых компах и ОС иногда SmartScreen винды программу за вирус принимал. Если купить такую ЭЦП и подписыват...
Дмитрий Завгородний
15
Карта сайта