Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.76/92: Рейтинг темы: голосов - 92, средняя оценка - 4.76
virua
1

Как работать со ссылками, длина которых превышает 255 символов

22.10.2012, 18:12. Показов 17705. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Есть прайс в формате Excel, сгенерированный с помощью PHP. В нем - ссылка "Купить" на определенный сайт на страницу заказа в формате:

httр://сайт/id_товара_1,количество_1|id_товара_2,количество_2|...

Ссылка такого формата формируется при выборе товаров в файле Excel. Для этого используется функция ГИПЕРССЫЛКА() и в нее передается длинная строка.

Но данная фунция, насколько я понимаю, не допускает более 255 символов в адресе. И тут проблемка!

Думаю, надо сделать текст или ячейку, которая бы действовала, как ссылка и по клику на него бросать пользователя в браузере по умолчанию на длинный (более 255 сим.) URL.

Но как это реализовать не знаю, потому что не имел дела с программированием для Excel.

P.S. Использовать сторонние сервисы для сокращения ссылок - не вариант.
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
22.10.2012, 18:12
Ответы с готовыми решениями:

Длина кода sql запроса превышает 255 символов
Всем привет. При написании sql запроса возникла сложность, а именно: в строке более 255 символов....

Длина кода sql-запроса превышает 255 символов
Здравствуйте помогите пожалуйста DataModule2.IBQuery1.SQL.Add('select...

Как работать с файлами, если длина их пути превышает 260 символов
Нужно работать с файлами к которым длинный путь, но если он больше 260 символов, вылетает...

Поиск файлов у которых длина имени более 255 символов
Написал программу которая должна при обращении к папке искать файлы длина имени у которых более 255...

3
2785 / 717 / 106
Регистрация: 04.02.2011
Сообщений: 1,443
22.10.2012, 18:36 2
В макрос обработки события, например при клике на кнопке впишите:
Visual Basic
1
Shell "explorer.exe " & s
В строквой переменной s должен быть адрес страницы, который может быть длиной свыше 256 знаков.
0
15151 / 6424 / 1731
Регистрация: 24.09.2011
Сообщений: 9,999
22.10.2012, 19:53 3
1. Зачем функция ГИПЕРССЫЛКА(), если файл создается программно?
Запишите макрорекордером в Excel создание гиперссылки с помощью команды Ctrl+K. Правда, не знаю, есть ли у такой гиперссылки ограничение по длине Никогда таких урлов не видел

2. У книги Excel есть параметр "база гиперссылки"
Visual Basic
1
workbook.BuiltinDocumentProperties("hyperlink base")
Его можно менять в диалоге "свойства". Попробуйте вписать туда постоянную часть, например httр://сайт, тогда на листе гиперссылки можно делать короче на эту часть.
0
2785 / 717 / 106
Регистрация: 04.02.2011
Сообщений: 1,443
23.10.2012, 11:06 4
Цитата Сообщение от Bill Gates, 1981
640 КБ должно быть достаточно для каждого
Цитата Сообщение от Excel Developers, 2012
256 символов должно быть достаточно для каждого URL
традиции все же!
1
23.10.2012, 11:06
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
23.10.2012, 11:06
Помогаю со студенческими работами здесь

Выбрать слова, длина которых превышает 5 символов
С клавиатуры вводится строка. Из неё нужно выбрать те слова, длина которых превышает 5. Затем...

Найти слова длина которых превышает 5 символов
Ввести текст, содержащий буквы и пробелы. Найти и напечатать слова и их количество, длина которых...

В ListBox помещаться только слова длина которых превышает 10 символов
Надо чтобы в ListBox помещаться только слова длина которых превышает 10 символов. Прошу помогите.

Подсчитать в строковой матрице количество слов, длина которых превышает 5 символов
Вводится массив К×М из слов. Подсчитать количество слов,размером больше 5 символов.


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru